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SECTION 1 
GENERAL DESCRIPTION 


The MC68HCO5JB3 is a member of the low-cost, high-performance M68HC05 
Family of 8-bit microcontroller units (MCUs). The M68HCO5 Family is based on 
the customer-specified integrated circuit design strategy. All MCUs in the family 
use the popular M68HCO5 central processing unit (CPU) and are available with a 
variety of subsystems, memory sizes and types, and package types. 


The MC68HCO5JB3 is specifically designed to be used in applications where a 
low speed (1.5Mbps) Universal Serial Bus (USB) interface is required. 


1.1 FEATURES 

¢ Industry standard M68HC05 CPU core 

¢ Memory-mapped input/output (I/O) registers 

* 2560 Bytes of user ROM 

* 144 Bytes of user RAM (includes 64 byte stack) 

¢ Fully compliant Low Speed USB with 3 Endpoints: 
— 1 Control Endpoint (2x8-byte buffer) 
— 2 Interrupt Endpoints (1x8-byte buffer shared) 

¢ 3.3V dc output for USB pull-up resistors 

¢ 19 Bidirectional I/O pins with the following features: 
— 17 1/Os have software programmable pull-down capability 


— 2 open-drain I/Os have software programmable pull-up, 25mA current 
sink capability 


— 41/Os with external interrupt capability 

— 8 1/Os (in 4 pairs) with programmable optical interface 
¢ Multi-Function Timer (MFT) 
¢ 16-bit Timer with 1 input capture and 1 output compare 
* Low Voltage Reset (LVR) 
* Computer Operating Properly (COP) Watchdog Reset 
« — Illegal Address Reset 
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* Power-Saving STOP and WAIT Modes 
* Available in 20-pin PDIP, 20-pin SOIC, 28-pin PDIP, and 28-pin SOIC 
packages 
1.2 MASK OPTIONS 
The following mask options are available: 


- External interrupt pins (IRQ, PAO to PA3): 
[edge-triggered or edge-and-level-triggered] 

¢ Port A, port B, and port C pull-down/pull-up resistors: 
[connected or disconnected] 


¢ PAO-PAS external interrupt capability: 
[enabled or disabled] 


* OSC, crystal/ceramic resonator startup delay: 
[4064 or 224 internal bus cycles] 


* Low Voltage Reset (LVR): 
[enabled or disabled] 


* COP function of MFT: 
[enabled or disabled] 
1.3 MCU STRUCTURE 
Figure 1-1 shows the structure of MC68HCO5JB3 MCU. 
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INDEX REG. 


STK PNTR 


PROGRAM COUNTER 


COND CODE REG. }t}1 ht |Nfzic 


2560 Bytes EPROM 


: External edge interrupt capability, 


: PBO is shared with TCAP 
:25mA current sink, open-drained 


@ ©®©6&®8 © 


®t: PCO shared with OCMP 


GENERAL DESCRIPTION 


with Schmitt trigger input and optical interface 
: 8mA current sink capability and optical interface 


with internal pull-up, slow transition O/P 
: Pins available in 28-pin package only 


Figure 1-1. MC68HCO5JB3 Block Diagram 
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PA4 
PBO/TCAP 
PBI 


20-pin package 


28-pin package 


Figure 1-2. MC68HC0O5JB3 Pin Assignments 


1.4 FUNCTIONAL PIN DESCRIPTION 


The following paragraphs give a description of the general function of each pin 
assigned in Figure 1-2. 


1.4.1 Vpp and Vss 


Power is supplied to the MCU through Vpp and Vggs. Vpp is the positive supply, 
and Vgs is ground. The MCU operates from a single power supply. 


Very fast signal transitions occur on the MCU pins. The short rise and fall times 
place very high short-duration current demands on the power supply. To prevent 
noise problems, special care should be taken to provide good power supply 
bypassing at the MCU by using bypass capacitors with good high-frequency char- 
acteristics that are positioned as close to the MCU as possible. Bypassing 
requirements vary, depending on how heavily the MCU pins are loaded. 


1.4.2 OSC1, OSC2 


The OSC1 and OSC2 pins are the connections for the on-chip oscillator. The 
OSC1 and OSC2 pins can accept the following sets of components: 


1. Acrystal as shown in Figure 1-3(a) 
2. Aceramic resonator as shown in Figure 1-3(a) 
3. An external clock signal as shown in Figure 1-3(b) 
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The frequency, fogc, of the oscillator or external clock source is divided by two to 
produce the internal operating frequency, fop If the internal operating frequency is 
3MHz, then the external oscillator frequency will be 6MHz. For LS USB 1.5MHz 
frequency clock can be derived from a divided by 4 circuit. The type of oscillator is 
selected by a mask option. An internal 2MQ resistor may be selected between 
OSC1 and OSC2 by a mask option (crystal/ceramic resonator mode only). 


Crystal Oscillator 


The circuit in Figure 1-3(a) shows a typical oscillator circuit for an AT-cut, parallel 
resonant crystal. The crystal manufacturer's recommendations should be fol- 
lowed, as the crystal parameters determine the external component values 
required to provide maximum stability and reliable start-up. The load capacitance 
values used in the oscillator circuit design should include all stray capacitances. 
The crystal and components should be mounted as close as possible to the pins 
for start-up stabilization and to minimize output distortion. An internal start-up 
resistor of approximately 2MQ is provided between OSC1 and OSC2 for the crys- 
tal type oscillator as a mask option. 


MCU MCU 
OSC1 OSC2 Osc1 OSC2 
2MQ if 
+—A\\-——> Unconnected 
cT™N cTN 
= — External Clock 
(a) Crystal or Ceramic Resonator Connections (b) External Clock Source Connection 


Figure 1-3. Oscillator Connections 


Ceramic Resonator Oscillator 


In cost-sensitive applications, a ceramic resonator can be used in place of the 
crystal. The circuit in Figure 1-3(a) can be used for a ceramic resonator. The res- 
onator manufacturer’s recommendations should be followed, as the resonator 
parameters determine the external component values required for maximum sta- 
bility and reliable starting. The load capacitance values used in the oscillator cir- 
cuit design should include all stray capacitances. The ceramic resonator and 
components should be mounted as close as possible to the pins for start-up stabi- 
lization and to minimize output distortion. An internal start-up resistor of approxi- 
mately 2 MQ is provided between OSC1 and OSC2 for the ceramic resonator type 
oscillator as a mask option. 
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1.4.3 


1.4.4 


1.4.5 


1.4.6 


1.4.7 


External Clock 


An external clock from another CMOS-compatible device can be connected to the 
OSC1 input, with the OSC2 input not connected, as shown in Figure 1-3(b). This 
configuration is possible ONLY when the crystal/ceramic resonator mask option is 
selected. 


RESET 


This is an I/O pin. This pin can be used as an input to reset the MCU to a known 
start-up state by pulling it to the low state. The RESET pin contains a steering 
diode to discharge any voltage on the pin to Vpp, when the power is removed. An 
internal pull-up is also connected between this pin and Vpp. The RESET pin con- 
tains an internal Schmitt trigger to improve its noise immunity as an input. This pin 
is an output pin if LVR triggers an internal reset. 


IRQ 


This input pin drives the asynchronous IRQ interrupt function of the CPU. The IRQ 
interrupt function has a mask option to provide either only negative edge-sensitive 
triggering or both negative edge-sensitive and low level-sensitive triggering. If the 
option is selected to include level-sensitive triggering, the IRQ input requires an 
external resistor to Vpp for "wired-OR" operation, if desired. The IRQ pin contains 
an internal Schmitt trigger as part of its input to improve noise immunity. 


NOTE 


Each of the PAO to PAS I/O pins may be connected as an OR function with the IRQ 
interrupt function by a mask option. This capability allows keyboard scan 
applications where the transitions or levels on the I/O pins will behave the same 
as the IRQ pin. The edge or level sensitivity selected by a separate mask option 
for the IRQ pin also applies to the I/O pins OR’ed to create the IRQ signal. 


3.3V 
This is an output reference voltage nominally set at 3.3V dc. 


D+ and D- 


These two lines carry the USB differential data. For low speed device such as 
MC68HCO5UJB3, a 1.5 kQ resistor is required to be connected across D- and 3.3V 
for proper signal termination. 


PAO-PA7 


These eight I/O lines comprise Port A. PAO to PA7 are push-pull pins with pull- 
down devices. The state of any pin is software programmable and all Port A lines 
are configured as inputs during power-on or reset. 
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PAO to PAS has external interrupt function (mask option) with schmitt trigger input 
circuit, and PA4 to PA7 has 8mA current sink capability. 


Port A can also be configured as the optical interface. 


1.4.8 PBO-PB2, PB3-PB7 
These seven I/O lines comprise Port B. The state of any pin is software program- 
mable and is configured as an input during power-on or reset. 
PB1 and PB2 are open-drain I/O lines with pull-up devices. PBO (shared with 
TCAP) is a push-pull I/O line with pull-down device. 
PB1 and PB2 are also slow transition outputs, each has 25mA current sink capa- 
bility at Vo, =0.5V. 
PB4-PB7 I/O lines are push-pull pins with pull-down devices, and are only avail- 
able in the 28-pin package. 
1.4.9 PCO-PC3 
These four I/O lines comprise Port C. The state of any pin is software programma- 
ble and all Port C lines are configured as inputs during power-on or reset. 
PCO to PC3 are push-pull pins with pull-down devices. PCO is also shared with the 
OCMP pin from the output compare function of the 16-bit timer. 
Port C is only available in the 28-pin package. 
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SECTION 2 
MEMORY 


The MC68HCO5JB3 has 8k-bytes of addressable memory, with 64 bytes of I/O, 
144 bytes of user RAM, and 2560 bytes of user ROM, as shown in Figure 2-1. 


GOO00|". — =a32 ST nt re art ea $0000 
I/O Registers 
64 Bytes 
$003F \/O Registers 
0040 PB 
$ Unused SAE 64 Bytes 
$006F 48 Bytes ils 
$0070 Peas $003F 
User RAM 
— 144 Bytes vi Reserved $1FFO 
Saeco ea Byte Stack : R d $1FFI 
‘ r 
$00FF yte Stac'! . eserve 
$0100 a Reserved $1FF2 
: Reserved $1FF3 
ines Rg MFT Vector (High Byte) | $1FF4 
4864 Bytes - MFT Vector (Low Byte) $1FF5 
‘ Timer1 Vector (High Byte) | $1FF6 
$13FF } Timer1 Vector (Low Byte) $1FF7 
$1400 i USB Vector (High Byte) $1FF8 
User ROM Fy USB Vector (Low Byte) $1FF9 
2560 Bytes s, IRQ Vector (High Byte) | $1FFA 
$1DFF i IRQ Vector (Low Byte) $1FFB 
1E00 : 
: Self-Check ROM rs SWI Vector (High Byte) $1FFC 
SiFEF #20 EVES be SWI Vector (Low Byte) | $1FED 
$1FFO Wisse Vectors Reset Vector (High Byte) | $1FFE 
$1FFF PRs on ns a ah Soclce ae Reset Vector (Low Byte) $1FFF 
Figure 2-1. MC68HCO5JB3 Memory Map 
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2.1 


2.2 


2.3 


/O AND CONTROL REGISTERS 


The I/O and Control Registers reside in locations $0000 to $003F. The bit assign- 
ments for each register are shown in Figure 2-2, Figure 2-3, Figure 2-4, and 
Figure 2-5. Reading from unused bits will return unknown states, and writing to 
unused bits will be ignored. 


RAM 


The user RAM consists of 144 bytes (including the stack) at locations $0080 to 
$012F. The stack begins at address $00FF and proceeds down to $00CO. Using 
the stack area for data storage or temporary work locations requires care to pre- 
vent it from being overwritten due to stacking from an interrupt or subroutine call. 


ROM 


There are a total of 3k-bytes of ROM on chip. This includes 2560 bytes of user 
ROM with locations $1400 to $1DFF for user program storage and 16 bytes for 
user vectors at locations $1FFO to $1FFF. Also, 496 bytes of Self-check ROM on 
chip at locations $1E00 to $1FEF. 
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2.4 W/OREGISTERS SUMMARY 


ADDR REGISTER R/W | BIT7 | BIT6 | BIT5 | BIT4 | BIT3 | BIT2 | BIT1 BIT 0 
$0000 noun pale a PA7 PA6 PA5 PA4 PAS PA2 PA1 PAO 
PORTA WwW 
$0001 eee a PB7 PB6 PB5 PB4 PB2 PB1 PBO 
PORTB WwW 
sado2|| bebe a pc3 | pc2 | pci | PCO 
PORTC WwW 
R 
$0003 Unused 
W 
Port A Data Direction} R 
$0004 DDRA W DDRA7 | DDRA6 | DDRA5 | DDRA4 | DDRA3 | DDRA2 | DDRA1 | DDRAO 
Port B Data Direction} R 
$0005 DDRB W DDRB7 | DDRB6 | DDRB5 | DDRB4 | SLOWE | DDRB2 | DDRB1 | DDRBO 
Port C Data Direction} R 
$0006 OCMPO | VROFF DDRC3 | DDRC2 | DDRC1 | DDRCO 
DDRC WwW 
R 
$0007 Unused 
W 
MFT Ctrl/Status R TOF RTIF 0 0 
$0008 TOFE RTIE -——-,——__ ART RTO 
TCSR WwW TOFR RTIFR 
$0009 MFT Counter R TMR7 TMR6 TMR5 TMR4 TMR3 TMR2 TMR1 TMRO 
TCNT WwW 
IRQ Control/Status R 0 0 0 IRQF 0 0 
000A IRQE IRQP 
$ ICSR WwW a IRQR ope 
R 
$000B Unused 
W 
R 
$000C Unused 
W 
R 
$000D Unused 
W 
Optical Interface En.| R 
$000E TCMPE | VREF2 | VREF1 | VREFO OIE3 OIE2 OIE1 OIEO 
OIER WwW 
$000F Port C Pull-down/up | R 
PDURC WwW PDRC3 | PDRC2 | PDRC1 | PDRCO 
unused bits reserved bits = 
Figure 2-2. MC68HC05JB3 I/O Registers $0000-$000F 
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ADDR REGISTER R/W | BIT7 | BIT6 | BIT5 | BIT4 | BIT3 | BIT2 | BIT1 | BITO 
$0010 Port A Pull-down/up R 
PDURA W_ | PDRA7 | PDRA6 | PDRA5 | PDRA4 | PDRA3 | PDRA2 | PDRA1 | PDRAO 
$0011 Port B Pull-down/up R 
PDURB W_ | PDRB7 | PDRB6 | PDRB5 | PDRB4 PURB2 | PURB1 | PDRBO 
Ti 1 Control R 0 0 0 0 
$0012 NSE Sone ICIE OCIE TOIE IEDG 
TCR Ww 
Timer1 Status R ICF OCF TOF 0 0 0 0 0 
$0013 
TSR Ww 
Input Capture MSB R ICH7 ICH6 ICH5 ICH4 ICH3 ICH2 ICH1 ICHO 
$0014 ER A AA NW A 
ICH Ww 
Input Capture LSB R ICL7 ICL6 ICL5 ICL4 ICL3 ICL2 ICL1 ICLO 
$0015 
ICL Ww 
Output C MSB;) R 
$0016 | par a7] OCH? | OCH | OCHS | OCH4 | OCHS | OCH2 | OCHT | OCHO 
Output C LSB} R 
$0017 | a | ocl7 | ocle | OCLs | ocl4 | ocis | ocL2 | ocLt | octo 
Timer1 Counter MSB} R- |TCNTH7|TCNTH6|TCNTHS5| TCNTH4)TCNTH3|TCNTH2/TCNTH1 | TCNTHO 
$0018 
TCNTH Ww 
Timer1 Counter LSB R | TCNTL7| TCNTL6) TCNTL5 | TCNTL4 | TCNTL3 | TCNTL2 | TCNTL1 | TCNTLO 
$0019 
TONTL Ww 
SO01A Alter. Counter MSB R  |ACNTH7|/ACNTH6|ACNTHS5)ACNTH4/ACNTH3/ACNTH2/ACNTH1 |ACNTHO 
ACNTH Ww 
$001B Alter. Counter LSB R  |ACNTL7|ACNTL6]ACNTL5 | ACNTL4 | ACNTL3 | ACNTL2 | ACNTL1 | ACNTLO 
ACNTL Ww 
R 
$001C Unused 
W 
R 
$001D Unused 
W 
R 
$001E Unused 
W 
R 
$001F Unused 
W 
unused bits reserved bits ‘ag | 
Figure 2-3. MC68HC05JB3 I/O Registers $0010-$001F 
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ADDR REGISTER R/W | BIT7 | BIT6 | BIT5 | BIT4 | BIT3 | BIT2 | BIT1 BITO 
$0020 USB Endpoint 0 DataO} R |UEORD7}/UEORD6/UEORD5/UEORD4|UEORD3|UEORD2|UEORD1 | UEORDO 
UDORO W_|UEOTD7 | UEOTD6 | UEOTDS5 | UEOTD4 | UEOTD3 | UEOTD2 | UEOTD1 | UEOTDO 
$0021 USB Endpoint 0 Data 1 R_ |UEORD7|UEORD6)UEORD5) UEORD4|UEORD3|UEORD2|UEORD1 |UEORDO 
UDOR1 W_|UEOTD7 | UEOTD6 | UEOTDS5 | UEOTD4 | UEOTD3 | UEOTD2 | UEOTD1 | UEOTDO 
$0022 USB Endpoint 0 Data2} R |UEORD7}/UEORD6/UEORD5/UEORD4|UEORD3|UEORD2|UEORD1 | UEORDO 
UDOR2 W_|UEOTD7 | UEOTD6 | UEOTDS5 | UEOTD4 | UEOTD3 | UEOTD2 | UEOTD1 | UEOTDO 
$0023 USB Endpoint 0 Data3} R |UEORD7}/UEORD6/UEORD5/UEORD4|UEORD3|UEORD2|UEORD1 | UEORDO 
UDOR3 W_|UEOTD7 | UEOTD6 | UEOTDS5 | UEOTD4 | UEOTD3 | VEOTD2 | UEOTD1 | UEOTDO 
$0024 USB Endpoint 0 Data4| R |UEORD7}/UEORD6/UEORD5/UEORD4|UEORD3|UEORD2|UEORD1 | UEORDO 
UDOR4 W_|UEOTD7 | UEOTD6 | UEOTD5 | UEOTD4 | UEOTD3 | UEOTD2 | UEOTD1 | UEOTDO 
$0025 USB Endpoint 0 Data5| R |UEORD7}/UEORD6/UEORD5/UEORD4|UEORD3|UEORD2|UEORD1 | UEORDO 
UDOR5 W_|UEOTD7 | UEOTD6 | UEOTDS5 | UEOTD4 | UEOTD3 | UEOTD2 | UEOTD1 | UEOTDO 
$0026 USB Endpoint 0 Data6| R |UEORD7}/UEORD6/UEORD5/UEORD4|UEORD3|UEORD2|UEORD1 | UEORDO 
UDOR6 W_|UEOTD7 | UEOTD6 | UEOTDS5 | UEOTD4 | UEOTD3 | UEOTD2 | UEOTD1 | UEOTDO 
$0027 USB Endpoint 0 Data7} R |UEORD7}/UEORD6/UEORD5/UEORD4|UEORD3|UEORD2|UEORD1 |UEORDO 
UDOR7 W_|UEOTD7 | UEOTD6 | UEOTDS5 | UEOTD4 | UEOTD3 | VEOTD2 | UEOTD1 | UEOTDO 
USB Endpoint 1 DataO} R 
ates UD1RO W_) |UE1TD7|UE1TD6|VE1TD5 | VE1TD4 | VE1TD3 | VE1TD2| UE1TD1 | UE1TDO 
USB Endpoint 1 Data 1 R 
were UD1R1 W_|UE1TD7|UE1TD6 | VE1TD5 | VE1TD4 | VE1TD3 | VE1TD2| UVE1TD1 | UE1TDO 
$002A USB Endpoint 1 Data2} R 
UD1R2 W_|UE1TD7|UE1TD6|VE1TD5 | VE1TD4 | VE1TD3 | VE1TD2| UE1TD1 | UE1TDO 
$002B USB Endpoint 1 Data3} R 
UD1R3 W_)|UE1TD7|UE1TD6|VE1TD5 | VE1TD4 | VE1TD3 | VE1TD2| UE1TD1 | UE1TDO 
$002C USB Endpoint 1 Data4| R 
UD1R4 W_ |UE1TD7|UE1TD6 | VE1TD5 | VE1TD4 | VE1TD3 | VE1TD2| UE1TD1 | UE1TDO 
$002D USB Endpoint 1 Data5|} R 
UD1R5 W_)|UE1TD7|UE1TD6 | VE1TD5 | VE1TD4 | VE1TD3 | VE1TD2| UE1TD1 | UE1TDO 
$002E USB Endpoint 1 Data6| R 
UD1R6 W_) |UE1TD7|UE1TD6 | VE1TD5 | VE1TD4 | VE1TD3 | VE1TD2| UE1TD1 | UE1TDO 
USB Endpoint 1 Data7} R 
ance UD1R7 W_|UE1TD7|UE1TD6 | VE1TD5 | VE1TD4 | VE1TD3 | VE1TD2| UVE1TD1 | UE1TDO 
unused bits reserved bits eal 
Figure 2-4. MC68HC05JB3 I/O Registers $0020-$002F 
MC68HC05JB3 MEMORY MOTOROLA 
REV 1 2-5 


For More Information On This Product, 
Go to: www.freescale.com 


Freescale Semiconductor, Inc. 
GENERAL RELEASE SPECIFICATION — November 5, 1998 


ADDR REGISTER R/W | BIT7 | BIT6 | BITS | BIT4 | BIT3 | BIT2 | BIT1 | BITO 


$0030 Unused 
$0031 Unused 
$0032 Unused 
$0033 Unused 
$0034 Unused 
$0035 Unused 
$0036 Unused 


USB Control 2 0 TX1ST 0 


S/Dl)S/Dl/S/D) Sil D) =) Dl Sl Dl=S/ DIS) Dl] S/H) S| DIS/ DI S/H! SS] DIS| DB 


0037 ENABLE2|ENABLE1| STALL2 | STALL1 
$ UCR2 TXiSTR 
USB Address 
$0038 ais USBEN | UADD6 | UADDS | UADD4 | UADD3 | UADD2 | UADD1 | UADDO 
USB Interrupt 0 TXDOF | RXDOF | RSTF 0 0 
$0039 SUSPND] TXDOIE | RXDOIE 
UIRO 0 0 0 TXDOFRIRXDOFR 
USB Interrupt 4 TXDIF | EOPF |RESUMF| 0 0 0 
$003A TXOUE | FORE 
UIR1 0 0 0 RESUMFR TXD1FR|} EOPFR 
USB Control 0 
$003B a. TOSEQ |STALLO| TXOE | RXOE |TPoOSIZ3|TPOSIZ2|TPOSIZ1 | TPOSIZO 
USB Control 1 
$003C co TiSEQ |ENDADD| TX1E |FRESUMITP1SIz3/TP1SIZ2|/TP1SIz1|TP1SIZO 
soosp| USB Status RSEQ | SETUP RPSsiz3 | RPSIz2 | RPSiz1 | RPSIZo 
USR 


unused bits asi reserved bits is 


Figure 2-5. MC68HCO5JB3 I/O Registers $0030-$003F 


ADDR REGISTER R/W | BIT7 | BIT6 | BIT5 | BIT4 | BIT3 | BIT2 | BIT1 | BITO 


COP Register R 0 0 0 0 0 0 0 0 
$1FFO 
COPR Ww COPR 
Figure 2-6. COP Register (COPR) 
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SECTION 3 
CENTRAL PROCESSING UNIT 


The MC68HCO5JB3 has an 8k-bytes memory map. The stack has only 64 bytes. 
Therefore, the stack pointer has been reduced to only 6 bits and will only 
decrement down to $00C0 and then wrap-around to $00FF. All other instructions 
and registers behave as described in this chapter. 


3.1. REGISTERS 


The MCU contains five registers which are hard-wired within the CPU and are not 
part of the memory map. These five registers are shown in Figure 3-1 and are 
described in the following paragraphs. 


7 6 i) 4 3 2 1 0 
T T T T T T T 
ACCUMULATOR A 
T T T T T T T 
INDEX REGISTER X 
15 14 13 #12 #11 ~~ «10 9 8 
T T T T T 
0 0 0 0 0 0 0 0 1 1 STACK POINTER SP 
| | i | | 
PROGRAM COUNTER PC 
CONDITION CODE REGISTER 1 1 1 H | N Z Cc ie 
HALF-CARRY BIT (FROM BIT 3) tl 
INTERRUPT MASK 
NEGATIVE BIT 
ZERO BIT 
CARRY BIT 


Figure 3-1. MC68HC05 Programming Model 
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3.2 


3.3 


3.4 


3.5 


ACCUMULATOR (A) 


The accumulator is a general purpose 8-bit register as shown in Figure 3-1. The 
CPU uses the accumulator to hold operands and results of arithmetic calculations 
or non-arithmetic operations. The accumulator is not affected by a reset of the 
device. 


INDEX REGISTER (X) 


The index register shown in Figure 3-1 is an 8-bit register that can perform two 
functions: 


¢ Indexed addressing 
¢ Temporary storage 


In indexed addressing with no offset, the index register contains the low byte of 
the operand address, and the high byte is assumed to be $00. In indexed 
addressing with an 8-bit offset, the CPU finds the operand address by adding the 
index register content to an 8-bit immediate value. In indexed addressing with a 
16-bit offset, the CPU finds the operand address by adding the index register 
content to a 16-bit immediate value. 


The index register can also serve as an auxiliary accumulator for temporary 
storage. The index register is not affected by a reset of the device. 


STACK POINTER (SP) 


The stack pointer shown in Figure 3-1 is a 16-bit register. In MCU devices with 
memory space less than 64k-bytes the unimplemented upper address lines are 
ignored. The stack pointer contains the address of the next free location on the 
stack. During a reset or the reset stack pointer (RSP) instruction, the stack pointer 
is set to $00FF. The stack pointer is then decremented as data is pushed onto the 
stack and incremented as data is pulled off the stack. 


When accessing memory, the ten most significant bits are permanently set to 
0000000011. The six least significant register bits are appended to these ten fixed 
bits to produce an address within the range of $00FF to $00CO. Subroutines and 
interrupts may use up to 64($C0) locations. If 64 locations are exceeded, the 
stack pointer wraps around and overwrites the previously stored information. A 
subroutine call occupies two locations on the stack and an interrupt uses five 
locations. 


PROGRAM COUNTER (PC) 


The program counter shown in Figure 3-1 is a 16-bit register. In MCU devices 
with memory space less than 64k-bytes the unimplemented upper address lines 
are ignored. The program counter contains the address of the next instruction or 
operand to be fetched. 
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Normally, the address in the program counter increments to the next sequential 
memory location every time an instruction or operand is fetched. Jump, branch, 
and interrupt operations load the program counter with an address other than that 
of the next sequential location. 


CONDITION CODE REGISTER (CCR) 


The CCR shown in Figure 3-1 is a 5-bit register in which four bits are used to 
indicate the results of the instruction just executed. The fifth bit is the interrupt 
mask. These bits can be individually tested by a program, and specific actions can 
be taken as a result of their states. The condition code register should be thought 
of as having three additional upper bits that are always ones. Only the interrupt 
mask is affected by a reset of the device. The following paragraphs explain the 
functions of the lower five bits of the condition code register. 


Half Carry Bit (H-Bit) 


When the half-carry bit is set, it means that a carry occurred between bits 3 and 4 
of the accumulator during the last ADD or ADC (add with carry) operation. The 
half-carry bit is required for binary-coded decimal (BCD) arithmetic operations. 


Interrupt Mask (I-Bit) 


When the interrupt mask is set, the internal and external interrupts are disabled. 
Interrupts are enabled when the interrupt mask is cleared. When an interrupt 
occurs, the interrupt mask is automatically set after the CPU registers are saved 
on the stack, but before the interrupt vector is fetched. If an interrupt request 
occurs while the interrupt mask is set, the interrupt request is latched. Normally, 
the interrupt is processed as soon as the interrupt mask is cleared. 


A return from interrupt (RTI) instruction pulls the CPU registers from the stack, 
restoring the interrupt mask to its state before the interrupt was encountered. After 
any reset, the interrupt mask is set and can only be cleared by the Clear I-Bit 
(CLI), or WAIT instructions. 


Negative Bit (N-Bit) 


The negative bit is set when the result of the last arithmetic operation, logical 
operation, or data manipulation was negative. (Bit 7 of the result was a logical 
one.) 


The negative bit can also be used to check an often tested flag by assigning the 
flag to bit 7 of a register or memory location. Loading the accumulator with the 
contents of that register or location then sets or clears the negative bit according 
to the state of the flag. 


Zero Bit (Z-Bit) 


The zero bit is set when the result of the last arithmetic operation, logical 
operation, data manipulation, or data load operation was zero. 
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3.6.5 Carry/Borrow Bit (C-Bit) 


The carry/borrow bit is set when a carry out of bit 7 of the accumulator occurred 
during the last arithmetic operation, logical operation, or data manipulation. The 
carry/borrow bit is also set or cleared during bit test and branch instructions and 
during shifts and rotates. This bit is neither set by an INC nor by a DEC instruction. 
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SECTION 4 
INTERRUPTS 


The MCU can be interrupted in six different ways: 


Non-maskable Software Interrupt Instruction (SW1) 
External Asynchronous Interrupt (IRQ) 

External Interrupt via IRQ on PAO-PA3 (mask option) 
USB Interrupt 

Timer Interrupt (16-bit Timer) 

Multi-Function Timer Interrupt 


4.1 INTERRUPT VECTORS 


Function 


Table 4-1. Reset/Interrupt Vector Addresses 


Control Priority Vector 
Bit (1 = Highest) Address 


Source 


Power-On Logic 
RESET Pin 

Low Voltage Reset $1FFE-$1F FF 

Illegal Address Reset 


COP Watchdog 


Software 
Interrupt (SWI) 


Same Priority 


As Instruction SIF PC CetEED 


User Code 


External 
Interrupt (IRQ) 


TRQ Pin IRQE Bit 2 $1FFA-$1FFB 


USB 
Interrupts 


Timer1 
Interrupts 


TXDOF TXDOIE 
TXD1F TXDI1IE $1FF8-$1FF9 
RESUMP _ 


ICF Bit ICIE Bit 
OCF Bit OCIE Bit $1FF6-$1FF7 
TOF Bit TOIE Bit 


MFT 
Interrupts 


MC68HCO05JB3 


REV 1 


CTOF Bit CTOFE Bit 


RTIF Bit RTIE Bit a 


$1FF2-$1FF3 
$1FFO-$1FF1 
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NOTE 


If more than one interrupt request is pending, the CPU fetches the vector of the 
higher priority interrupt first. A higher priority interrupt does not actually interrupt a 
lower priority interrupt service routine unless the lower priority interrupt service 
routine clears the | bit. 


4.2 INTERRUPT PROCESSING 
The CPU does the following actions to begin servicing an interrupt: 
* Stores the CPU registers on the stack in the order shown in Figure 4-1. 
¢ Sets the | bit in the condition code register to prevent further interrupts. 
¢ Loads the program counter with the contents of the appropriate interrupt 
vector locations as shown in Table 4-1. 
The return from interrupt (RTI) instruction causes the CPU to recover its register 
contents from the stack as shown in Figure 4-1. The sequence of events caused 
by an interrupt are shown in the flow chart in Figure 4-2. 
$0020 (BOTTOM OF RAM) 
$0021 
$00BE 
$00BF 
$00C0 (BOTTOM OF STACK) 
$00C1 
$00C2 UNSTACKING 
ORDER 
u 
n CONDITION CODE REGISTER 5 1 
n+1 ACCUMULATOR 4 2 
n+2 INDEX REGISTER 3 3 
n+3} PROGRAM COUNTER (HIGH BYTE) 2 4 
n+4| PROGRAM COUNTER (LOW BYTE) 1 5 
tt 
STACKING 
$00FD ORDER 
$00FE 
$00FF TOP OF STACK (RAM) 
Figure 4-1. Interrupt Stacking Order 
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FROM 
RESET 


EXTERNAL 
INTERRUPT? 


CLEAR IRQ LATCH. 


USB 
INTERRUPT? 


TIMER1 Y 


ES 
INTERRUPT? 
NO 
MFT YES 


INTERRUPT? 


FETCH NEXT 
INSTRUCTION. 


STACK PCL, PCH, X, A, CCR. 
SET | BIT. 
LOAD PC WITH INTERRUPT VECTOR. 


RTI 
INSTRUCTION? - UNSTACK CCR, A, X, PCH, PCL. ie 
EXECUTE INSTRUCTION. 


Figure 4-2. Interrupt Flowchart 
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4.3 


4.4 


4.5 


4.5.1 


RESET INTERRUPT SEQUENCE 


The RESET function is not in the strictest sense an interrupt; however, it is acted 
upon in a similar manner as shown in Figure 4-2. A low level input on the RESET 
pin or an internally generated RST signal causes the program to vector to its start- 
ing address which is specified by the contents of memory locations $1FFE and 
$1FFF. The I-bit in the condition code register is also set. 


SOFTWARE INTERRUPT (SWI) 


The SWI is an executable instruction and a non-maskable interrupt since it is exe- 
cuted regardless of the state of the I-bit in the CCR. As with any instruction, inter- 
rupts pending during the previous instruction will be serviced before the SWI 
opcode is fetched. The interrupt service routine address is specified by the con- 
tents of memory locations $1FFC and $1FFD. 


HARDWARE INTERRUPTS 


All hardware interrupts except RESET are maskable by the I-bit in the CCR. If the 
l-bit is set, all hardware interrupts (internal and external) are disabled. Clearing 
the I-bit enables the hardware interrupts. There are two types of hardware inter- 
rupts which are explained in the following sections. 


External Interrupt IRQ 


The IRQ pin provides an asynchronous interrupt to the CPU. A block diagram of 
the IRQ logic is shown in Figure 4-3. 


The IRQ pin is one source of an IRQ interrupt and a mask option can also enable 
the four lower Port-A pins (PAO to PA3) to act as other IRQ interrupt sources. 


Refer to Figure 4-3 for the following descriptions. IRQ interrupt source comes 
from IRQ latch. The IRQ latch will be set on the falling edge of the IRQ pin or on 
any falling edge of PAO-3 pins if PAO-3 interrupts have been enabled. If ‘edge-only’ 
sensitivity is chosen by a mask option, only the IRQ latch output can activate an 
IRQF flag which creates a request to the CPU to generate the IRQ interrupt 
sequence. This makes the IRQ interrupt sensitive to the following cases: 


1. Falling edge on the IRQ pin. 
2. Falling edge on any PAO-PAS pin with IRQ enabled (via mask option). 


If level sensitivity is chosen, the active high state of the signal to the clock input of 
the IRQ latch can also activate an IRQF flag which creates an IRQ request to the 
CPU to generate the IRQ interrupt sequence. This makes the IRQ interrupt sensi- 
tive to the following cases: 


1. Low level on the IRQ pin. 

2. Falling edge on the IRQ pin. 

3. Low level on any PAO-PA3 pin with IRQ enabled (via mask option). 

4. Falling edge on any PAO-PA3 pin with IRQ enabled (via mask option). 
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The IRQE enable bit controls whether an active IRQF flag can generate an IRQ 
interrupt sequence. This interrupt is serviced by the interrupt service routine 
located at the address specified by the contents of $1FFA and $1FFB. 


If IRQF is set, the only way to clear this flag is by writing a logic one to the IRQR 
acknowledge bit in the ICSR. As long as the output state of the IRQF flag bit is 
active the CPU will continuously re-enter the IRQ interrupt sequence until the 
active state is removed or the IRQE enable bit is cleared. 


TO BIH & BIL 


PAO ——_ 


PA3 —— 


PA1 — |_ 


IRQ Level 


(Mask Optio 


Port A External Interrupt 
(Mask Option) 


n) 


RST 7 


IRQ VECTOR FETCH 


IRQE 


IRQF 


| Vv | 


IRQR 


2 INSTRUCTION 


PROCESSING 


S. 


IRQ STATUS/CONTROL REGISTER 


INTERNAL DATA BUS 


SY 


Figure 4-3. External Interrupt (IRQ) Logic 


4.5.2 IRQ Control/Status Register (ICSR) - $0A 


The IRQ interrupt function is controlled by the ICSR located at $000A. All unused 
bits in the ICSR will read as logic zeros. The IRQF bit is cleared and IRQE bit is 


set by reset. 


EXTERNAL 
INTERRUPT 
REQUEST 


BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
ICSR I see 0 0 0 IRQF 0 0 BeBe 
$000A |W IRQR 
reset: 1 0 0 0 0 0 0 0 
Figure 4-4. IRQ Control and Status Register (ICSR) 
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IRQPU — IRQ pin PUll-up resistor enable 
This bit enables/disables the internal pull-up resistor on the IRQ pin. 
1 = Internal pull-up resistor in IRQ pin enabled. 
0 = Internal pull-up resistor in IRQ pin disabled. 


IRQR — IRQ Interrupt Acknowledge 
This write-only bit clears an IRQ interrupt by clearing the IRQ latch, and hence 
the IRQF bit. The IRQR bit will always read as a logic zero. 
1= Clears IRQ interrupt request (clears IRQF). 
O= Noeffect. 
IRQF — IRQ Interrupt Request Flag 
Writing to the IRQF flag bit will have no effect on it. If the additional setting of 
IRQF flag bit is not cleared in the IRQ service routine and the IRQE enable bit 
remains set the CPU will re-enter the IRQ interrupt sequence continuously until 
either the IRQF flag bit or the IRQE enable bit is clear. The IRQF latch is 
cleared by reset. 
1 = Indicates that an IRQ request is pending. 
0= Indicates that no IRQ request triggered by pins PAO-3 or IRQ is 
pending. The IRQF flag bit can be cleared by writing a logic one to 
the IRQR acknowledge bit to clear the IRQ latch and also 
conditioning the external IRQ sources to be inactive (if the level 
sensitive interrupts are enabled via mask option). Doing so before 
exiting the service routine will mask out additional occurrences of 
the IRQF. 


IRQE — IRQ Interrupt Enable 
The IRQE bit enables/disables the IRQF flag bit to initiate an IRQ interrupt 
sequence. 

1 = Enables IRQ interrupt, that is, the IRQF flag bit can generate an 
interrupt sequence. Reset sets the IRQE enable bit, thereby 
enabling IRQ interrupts once the I-bit is cleared. Execution of the 
STOP or WAIT instructions causes the IRQE bit to be set in order to 
allow the external IRQ to exit these modes. 

0= The IRQF flag bit cannot generate an interrupt sequence. 


4.5.3 Port A External Interrupts (PAO-PA3, by mask option) 


The IRQ interrupt can also be triggered by the inputs on the PAO to PA3 port pins 
if enabled by a single mask option. If enabled, the lower four bits of Port A can 
activate the IRQ interrupt function, and the interrupt operation will be the same as 
for inputs to the IRQ pin. This mask option of PAO-3 interrupt allow all of these 
input pins to be OR’ed with the input present on the IRQ pin. All PAO to PAS pins 
must be selected as a group as an additional IRQ interrupt. All the PAO-3 interrupt 
sources are also controlled by the IRQE enable bit. 
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NOTE 


The BIH and BIL instructions will only apply to the level on the IRQ pin itself, and 
not to the output of the logic OR function with the PAO to PA3 pins. The state of the 
individual Port A pins can be checked by reading the appropriate Port A pins as 
inputs. 


NOTE 


If enabled, the PAO to PA3 pins will cause an IRQ interrupt only when the 
corresponding pin is configured as input. 


Timer1 Interrupt (TIMER1) 


The TIMER1 interrupt is generated by the 16-bit timer when either an overflow or 
an input capture or output compare has occurred as described in the section on 
16-bit timer. The interrupt flags and enable bits for the Timer1 interrupts are 
located in the Timer1 Control & Status Register (TSR) located at $0012, $0013. 
The I-bit in the CCR must be clear in order for the TIMER1 interrupt to be enabled. 
Either of these three interrupts will vector to the same interrupt service routine 
located at the address specified by the contents of memory locations $1FF6 and 
$1FF7. 


USB Interrupt (USB) 


The USB interrupt is generated by the USB module as described in the section on 
Universal Serial Bus. The interrupt enable bits for the USB interrupt are located at 
bit3-bit2 of UIRO register and bit3-bit2 of UIR1 register. Also Once the device goes 
into Suspend Mode, any bus activities will cause the USB to generate an interrupt 
to CPU to come out from the Suspend mode. The I-bit in the CCR must be clear in 
order for the USB interrupt to be enabled. Either of these two interrupts will vector 
to the same interrupt service routine located at the address specified by the con- 
tents of memory locations $1FF8 and $1FF9. 


MFT Interrupt (MFT) 


The MFT interrupt is generated by the MFT module as described in the section on 
Multi-function Timer. These interrupts will vector to the same interrupt service rou- 
tine located at the address specified by the contents of memory locations $1FF4 
and $1FF5. 
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SECTION 5 
RESETS 


This section describes the six reset sources and how they initialize the MCU. A 
reset immediately stops the operation of the instruction being executed, initializes 
certain control bits, and loads the program counter with a user defined reset vec- 
tor address. The following conditions produce a reset: 


¢ — Initial power up of device (power on reset). 

¢ A logic zero applied to the RESET pin (external reset). 
¢ Timeout of the COP watchdog (COP reset). 

* Low voltage applied to the device (LVR reset). 


* Fetch of an opcode from an address not in the memory map (illegal 
address reset). 


¢ Detection of USB reset signal (USB reset). 
Figure 5-1 shows a block diagram of the reset sources and their interaction. 


Vpp POWER-ON RESET 


L_____ INTERNAL 
ADDRESS BUS 


RESET i> lo TO CPU 
SUBSYSTEMS 
: CE INTERNAL 
CLOCK 
Figure 5-1. Reset Sources 
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5.1 


5.2 


5.3 


5.3.1 


POWER-ON RESET 


A positive transition on the Vpp pin generates a power-on reset. The power-on 
reset is strictly for conditions during powering up and cannot be used to detect 
drops in power supply voltage. 


A 224tcyc or 4064 tey¢ (internal clock cycle) delay after the oscillator becomes 
active allows the clock generator to stabilize. If the RESET pin is at logic zero at 
the end of the multiple tcy¢ time, the MCU remains in the reset condition until the 
signal on the RESET pin goes to a logic one. 


EXTERNAL RESET 


A logic zero applied to the RESET pin for 1.5tcye generates an external reset. 
This pin is connected to a Schmitt trigger input gate to provide and upper and 
lower threshold voltage separated by a minimum amount of hysteresis. The exter- 
nal reset occurs whenever the RESET pin is pulled below the lower threshold and 
remains in reset until the RESET pin rises above the upper threshold. This active 
low input will generate the internal RST signal that resets the CPU and peripher- 
als. 


The RESET pin can also act as an open drain output. It will be pulled to a low 
state by an internal pulldown device that is activated by three internal reset 
sources. This RESET pulldown device will only be asserted for 3 to 4 cycles of the 
internal clock, fop or as long as the internal reset source is asserted. When the 
external RESET pin is asserted, the pulldown device will not be turned on. 


NOTE 


Do not connect the RESET pin directly to Vpp, as this may overload some power 
supply designs when the internal pulldown on the RESET pin activates. 


INTERNAL RESETS 


The five internally generated resets are the initial power-on reset function, the 
COP Watchdog timer reset, the low voltage reset, and the illegal address detector. 
Only the COP Watchdog timer reset, low voltage reset and illegal address detec- 
tor will also assert the pulldown device on the RESET pin for the duration of the 
reset function or 3 to 4 internal clock cycles, whichever is longer. 


Power-On Reset (POR) 


The internal POR is generated on power-up to allow the clock oscillator to stabi- 
lize. The POR is strictly for power turn-on conditions and is not able to detect a 
drop in the power supply voltage (brown-out). There is an oscillator stabilization 
delay of 224 or 4064 (224 or 4064 is selected by mask option) internal processor 
bus clock cycles after the oscillator becomes active. 
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The POR will generate the RST signal which will reset the CPU. If any other reset 
function is active at the end of the 224 or 4064 cycle delay, the RST signal will 
remain in the reset condition until the other reset condition(s) end. 


POR will not activate the pulldown device on the RESET pin. Vpp must drop 
below Vpop in order for the internal POR circuit to detect the next rise of Vpp. 


USB Reset 


The USB reset is generated by a detection on the USB bus reset signal. For 
MC68HCO5JB3, seeing a single-end zero on its upstream port for 4 to 8 bit times 
will set RSTF bit in UIRO register. The detections will also generate the RST signal 
to reset the CPU and other peripherals in the MCU. 


Computer Operating Properly (COP) Reset 
The COP watchdog is enabled by a mask option. 


A timeout of the COP watchdog generates a COP reset. The COP watchdog is 
part of a software error detection system and must be cleared periodically to start 
a new timeout period. To clear the COP watchdog and prevent a COP reset, write 
a logic zero to the COPC bit of the COP register at location $1FFO. 


BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
COPR R 0 0 0 0 0 0 0 0 
$1FFO W COPC 
reset: U U U U U U U 0 
U = UNAFFECTED BY RESET 


Figure 5-2. COP Watchdog Register (COPR) 


COPC — COP Clear 
COPC is a write-only bit. Periodically writing a logic zero to COPC prevents the 
COP watchdog from resetting the MCU. Reset clears the COPC bit. 
1= No effect on system. 
0= Reset COP watchdog timer. 


The COP Watchdog reset will assert the pull-down device to pull the RESET pin 
low for one cycle of the internal bus clock. 


Refer to section on Multi-Function Timer for detail on COP watchdog timeout peri- 
ods. 


Low Voltage Reset (LVR) 


The LVR activates the RST reset signal to reset the device when the voltage on 
the Vpp pin falls below the LVR trip voltage. The LVR will assert the pulldown 
device to pull the RESET pin low one cycle of the internal bus clock. The Low Volt- 
age Reset circuit is enabled by a mask option. 
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5.3.5 Illegal Address Reset 


An opcode fetch from an address that is not in the ROM or the RAM generates an 
illegal address reset. The illegal address reset will assert the pull-down device to 
pull the RESET pin low for 3 to 4 cycles of the internal bus clock. 
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SECTION 6 
LOW POWER MODES 


There are three modes of operation that reduce power consumption: 
* Stop mode 
* Wait mode 
¢ Data retention mode 

Figure 6-1 shows the sequence of events in Stop and Wait modes. 
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STOP EXTERNAL OSCILLATOR, 
STOP INTERNAL TIMER CLOCK, EXTERNAL OSCILLATOR ACTIVE, 
RESET STARTUP DELAY INTERNAL TIMER CLOCK ACTIVE 
STOP INTERNAL PROCESSOR CLOCK, STOP INTERNAL PROCESSOR CLOCK, 
CLEAR |-BIT IN CCR, CLEAR -BIT IN CCR, 
SET IRQE IN ICSR SET IRQE IN ICSR 


EXTERNAL 
RESET? 


EXTERNAL 
RESET? 


IRQ 
EXTERNAL 
INTERRUPT? 


IRQ 
EXTERNAL 
INTERRUPT? 


YES YES 


USB 
RESET OR 
INTERRUPT? 


YES 


USB 
INTERRUPT 
OR RESET? 


YES 


YE TIMER? 
v S INTERNAL 
INTERRUPT? 
RESTART EXTERNAL OSCILLATOR, 
START STABILIZATION DELAY 


MFT 
INTERNAL 
INTERRUPT? 


YES 


END OF 
STABILIZATION 
DELAY? 


Lae y 
<—______— 
Y 
RESTART INTERNAL PROCESSOR CLOCK 
Y 
1. LOAD PC WITH RESET VECTOR 
OR 


2. SERVICE INTERRUPT. 


a. SAVE CPU REGISTERS ON STACK. 
b. SET | BIT IN CCR. 
c. LOAD PC WITH INTERRUPT VECTOR. 


Figure 6-1. STOP and WAIT Flowchart 
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STOP MODE 


STOP mode is entered by executing the STOP instruction. This is the lowest 
power consumption mode of the MCU. In the STOP Mode the internal oscillator is 
turned off, halting all internal processing. 


Execution of the STOP instruction automatically clears the I-bit in the Condition 
Code Register and sets the IRQE enable bit in the IRQ Control/Status Register so 
that the IRQ external interrupt is enabled. All other registers, including the other 
bits in the TCSR, and memory remain unaltered. All input/output lines remain 
unchanged. 


The MCU can be brought out of the STOP Mode by an IRQ external interrupt or a 
USB coming out from Suspend Mode Interrupt (Bus activity detection) or an exter- 
nally generated RESET, USB Reset or an LVR reset. When exiting the STOP 
Mode the internal oscillator will resume after a 224 or 4064 internal processor 
clock cycle oscillator stabilization delay. 


WAIT MODE 


WAIT mode is entered by executing the WAIT instruction. This places the MCU in 
a low-power mode, which consumes more power than the STOP Mode. In the 
WAIT Mode the internal processor clock is halted, suspending all processor and 
internal bus activity. Execution of the WAIT instruction automatically clears the I-bit 
in the Condition Code Register and sets the IRQE enable bit in the IRQ Control/ 
Status Register so that the IRQ external interrupt is enabled. All other registers, 
memory, and input/output lines remain in their previous states. 


The WAIT Mode may be exited when an external IRQ, USB, Timer1 or MFT inter- 
rupt, an LVR reset, USB reset or an external RESET occurs. 


DATA-RETENTION MODE 


The Data-Retention mode is only available if the Low Voltage Reset function 
(mask option) is not enabled. 


In the data retention mode, the MCU retains RAM contents and CPU register con- 
tents at Vpp voltages as low as 2Vdc. The data retention feature allows the MCU 
to remain in a low power consumption state during which it retains data, but the 
CPU cannot execute instructions. The RESET pin must be held low during data- 
retention mode. 
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SECTION 7 
INPUT/OUTPUT PORTS 
In normal operating mode there are 19 usable bidirectional I/O lines arranged as 
one 8-bit I/O port (Port-A), one 7-bit I/O port (Port-B), and one 4-bit I/O port 


(Port C). The individual bits in these ports are programmable as either inputs or 
outputs under software control by the data direction registers (DDRs). 


The eight port pins, PB4-PB7 and PCO-PC3, are only available on the 28-pin 
version of the device. 


Table 7-1 shows a summary of Port-A, Port-B, and Port-C functions. 


Table 7-1. Summary of Port Pin Functions 


Port Pins 


Internal Resistor Current 


Configuration Drive/Sink maditonale cartes 


PAO-PA3 1.6mA sink External Interrupt? 
Optical Interface 
PA4-PA7 Pull-down! 8mA sink 
PBO 


1.6mA sink shared with TCAP 


PB1, PB2 Pull-up | 


25mA sink, 


: Slow Transition Output 
open-drain 


PB4-PB7 


Pull-down! 1.6mA sink shared with OCMP Pe ravalae Only 
in 28-pin device 
PC1-PC3 


Notes: 


1. A pull-up/pull-down resistor is enabled by setting the corresponding register bit to “O” and the 
port pull-up/down mask option is selected. 


2. Selected by mask option. 


7.1. PORT-A 
Port-A is an 8-bit bi-directional port. The Port-A data register is at $0000 and the 
data direction register (DDRA) is at $0004. Reset does not affect the data regis- 
ters, but clears the data direction registers, thereby returning the port pins to 
inputs. Writing a ‘1’ to a DDR bit sets the corresponding port bit to output mode. 
All Port-A pins have programmable pull-down resistors. PA4 to PA7 each has 8mA 
current sink capability. 
The table below summarizes the pin configurations for Port-A. 
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PDRAx DDRAx Pin Configuration 
0 0 Input with pull-down 
0 1 Output Push/Pull 
1 0 Input 
1 1 Output Push/Pull 
7.1.1 Port-A Data Register 
BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
PORTA |R 
PA7 PAG PA5 PA4 PA3 PA2 PA1 PAO 
$0000 = |W 
reset: 0 0 0 0 0 0 0 0 
7.1.2 Port-A Data Direction Register 
BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
DDRA [R 
DDRA7 | DDRA6 | DDRAS | DDRA4 | DDRA3 | DDRA2 | DDRA1 | DDRAO 
$0004 = |W 
reset: 0 0 0 0 0 0 0 0 
DDRAx — PAx Data Direction 
1= Port pin set as output. 
0= Port pin set as input. 
7.1.3 Port-A Pull-down/up Register 
With the pull-up/down mask option selected, each pin in Port-A has an internal 
pull-down resistor which can be enabled by writing a ‘0’ to the corresponding bit in 
the Port-A pull-down/up control register (PDURA) at location $0010. 
BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
PDURA |R 
$0010 |W) PDRA7 | PDRA7 | PDRA7 | PDRA7 | PDRA7 | PDRA7 | PDRA7 | PDRA7 
reset: 0 0 0 0 0 0 0 0 
PDRAx — PAx Pin Pull-down enable 
1 = Internal pull-down disabled. 
0= Internal pull-down enabled. 
7.1.4 PAO-PA3 Interrupts 
A mask option selects the capability for PAO-PA3 to be used as external IRQ inter- 
rupt inputs. These four I/O pins also have schmitt trigger input circuits. 
See INTERRUPTS section for detail. 
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PAO-PA7 Optical Interface 
Port-A is programmable to use as ports for the optical interface. 
See OPTICAL INTERFACE section for details. 


7.2 PORT-B 
Port-B is a 7-bit bi-directional port. The Port-B data register is at $0001 and the 
data direction register (DDRB) is at $0005. Reset does not affect the data regis- 
ters, but clears the data direction registers, thereby returning the port pins to 
inputs. Writing a ‘one’ to a DDR bit sets the corresponding port bit to output mode. 
PB4-PB7 are only available on the 28-pin version of the device. 
All Port-B pins have programmable pull-down or pull-up resistors. PB1 and PB2 
each has 25mA current sink capability. 
PBO is also used as the 16-timer TCAP input pin. When configured as output, the 
input to the input capture will be permanently tied “low” and no input capture can 
be generated. 
The table below summarizes the pin configurations for Port-B. 
PDRBx/PURBx DDRBx Pin Configuration 
0 0 PBO, PB4-PB7: Input with pull-down 
PB1, PB2: Input with pull-up 
0 1 PBO, PB4-PB7: Output Push-Pull 
PB1, PB2: Output Open-drain with pull-up 
1 0 Input 
{ 1 PBO, PB4-PB7: Output Push-Pull 
PB1, PB2: Output Open-drain 
7.2.1 Port-B Data Register 
BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
PORTB. |R 0 
PB7 PB6 PB5 PB4 PB2 PBI PBO 
$0001 w 
reset: 0 0 0 0 0 0 0 0 
7.2.2 Port-B Data Direction Register 
BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
DDRB R 
DDRB7 | DDRB6 | DDRB5 | DDRB4 | SLOWE | DDRB2 | DDRB1 | DDRBO 
$0005 = |W 
reset: 0 0 0 0 0 0 0 0 
DDRBx — PBx Data Direction 
1 = Port pin set as output. 
0= Port pin set as input. 
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SLOWE — Slow Transition Enable 
See Section 7.2.4 for details. 
1 = Enable slow falling-edge output transition feature on PB1 and PB2. 
0= Disable slow falling-edge output transition feature on PB1 and PB2. 


7.2.3 Port-B Pull-down/up Register 
With the pull-up/down mask option selected, PBO and PB4-PB7 each has an inter- 
nal pull-down resistor, while PB1 and PB2 each has an internal pull-up resistor, 
which can be enabled by writing a ‘0’ to the corresponding bit in the Port-B 
pull-down/up control register (PDURB) at location $0011. 
BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
PDURB |R 
$0011 W| PDRB7 | PDRB6 | PDRB5 | PDRB4 PURB2 | PURB1 | PDRBO 
reset: 0 0 0 0 0 0 0 0 
PDRBx — PBx Pin Pull-down enable 
1 = Internal pull-down disabled. 
0= Internal pull-down enabled. 
PURBx — PBx Pin Pull-up enable 
1 = Internal pull-up disabled. 
0= Internal pull-up enabled. 
7.2.4 PB1, PB2 Slow Transition Output 
The slow transition output feature is enabled by setting the SLOWE bit in DDRB at 
$0005. 
PB2 — a high-to-low output transition is a sharp falling edge transition delayed by 
tcyc +2. 
PB1 — a high-to-low output transition is a slow falling edge (drops from 5.0V to 
2.2V in 167ns typically at fo6p=3MHz, with 50pF load) followed by a fast transition 
to Vss. The fast transition duration is depending on the strength of the output 
driver defined for each port. See Figure 7-1. 
Both PB1 and PB2 have 25mA current sink capability. 
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Figure 7-1. PB1 Slow Falling-edge Output 
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7.3. PORT-C 
Port-C is a 4-bit bi-directional port. The Port-C data register is at $0002 and the 
data direction register (DDRC) is at $0006. Reset does not affect the data regis- 
ters, but clears the data direction registers, thereby returning the port pins to 
inputs. Writing a ‘one’ to a DDR bit sets the corresponding port bit to output mode. 
All Port-C pins have programmable pull-down resistors, and are only available on 
the 28-pin version of the device. 
PCO is also used as the 16-timer OCMP output pin. 
The table below summarizes the pin configurations for Port-A. 
PDRCx DDRCx Pin Configuration 
0 0 Input with pull-down 
0 1 Output Push-Pull 
1 0 Input 
1 1 Output Push-Pull 
7.3.1 Port-C Data Register 
BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
ee PC3 PC2 PC1 PCO 
$0002 |W 
reset: 0 0 0 0 0 0 0 0 
7.3.2 Port-C Data Direction Register 
BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
DDRC [R 
OCMPO | VROFF DDRC3 | DDRC2 | DDRC1 | DDRCO 
$0006 ~=—s |W 
reset: 0 0 0 0 0 0 0 0 
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DDRCx — PCx Data Direction 
1= Port pin set as output. 
0= Port pin set as input. 


VROFF — USB 3.3V Voltage Reference 
See USB section for details. 
1= Disable 3.3V regulator. 
0= Enables 3.3V regulator. 


OCMPO — OCMP Output Enable 
See 16-BIT TIMER section for details. 
1= PCO is OCMP pin, OCF from 16-bit timer output compare. 
0= PCO is standard I/O pin, from Port-C data register. 


7.3.3 Port-C Pull-down/up Register 
With the pull-up/down mask option selected, each pin in Port-C has an internal 
pull-down resistor which can be enabled by writing a ‘0’ to the corresponding bit in 
the Port-C pull-down/up control register (PDURC) at location $000F. 
BIT7 BIT 6 BIT5 BIT 4 BIT3 BIT 2 BIT 1 BIT 0 
PDURC |R 
$000F |W PDRC3 | PDRC2 | PDRC1 | PDRCO 
reset: 0 0 0 0 0 0 0 0 
PDRCx — PCx Pin Pull-down Enable 
1 = Internal pull-down disabled. 
0= Internal pull-down enabled. 
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SECTION 8 


MULTI-FUNCTION TIMER 


The Multi-Function Timer (or Core Timer) module is a 15-stage ripple counter with 
Timer Over Flow (CTOF), Real Time Interrupt (RTI), and COP Watchdog function. 


MCU Internal Bus 


| 


Internal 


+4 <— Timer Clock 


(NTF1) 


COP Watchdog 
Resetable Timer 


(+8) 


8 8 
Timer Counter Register ($09) 
fopz2? 
|}<{—————— 
aol) 
7-bit counter 
~<a 
BOUT gphOe apt |agle 
Y Y Y Y 
i ‘ ——__ _—_—_—{ 
RTI Select Circuit 
Overflow 
Detect | @ 
Circuit 
Y Y Timer Control & Status Register ($08) 
CTOF | RTIF |CTOFE} RTIE JCTOFR/RTIFR| RT1 | RTO 
yyy y 
Interrupt Circuit 
to CPU interrupt 
Figure 8-1. Multi-Function Timer Block Diagram 
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8.1 


8.2 


8.3 
8.3.1 


OVERVIEW 


As shown in Figure 8-1, the Timer is driven by the timer clock, NTF 1, divided by 
four. NTF1 has the same phase and frequency as the processor bus clock, PH2, 
but continues to run in WAIT mode. The NTF1 drives an 8-bit ripple counter. The 
value of this 8-bit ripple counter can be read by the CPU at any time by accessing 
the Timer Counter Register (TCNT) at address $09. A timer overflow function is 
implemented on the last stage of this 8-bit counter, giving a possible interrupt rate 
of fop +1024. 


The last stage of the 8-bit counter also drives a further 7-bit counter. The final four 
stages is used by the RTI circuit, giving possible RTI rates of fop+2'4, 215, 2! or 
217 selected by RT1 and RTO (see Table 8-1). The RTI rate selector bits, and the 
RT| and CTOF enable bits and flags are located in the Timer Control and Status 
Register at location $08. 


The power-on cycle clears the entire counter chain and begins clocking the 
counter. After 224 or 4064 cycles, the power-on reset circuit is released which 
again clears the counter chain and allows the device to come out of reset. At this 
point, if RESET is not asserted, the timer will start counting up from zero and nor- 
mal device operation will begin. If RESET is asserted at any time during operation 
the counter chain will be cleared. 


COMPUTER OPERATING PROPERLY (COP) WATCHDOG 
The COP Watchdog is enabled by a mask option. 


The COP Watchdog Timer function is implemented by using the output of the RT! 
circuit and further dividing it by eight. The minimum COP reset rates are listed in 
Table 8-1. If the COP circuit times out, an internal reset is generated and the nor- 
mal reset vector is fetched. 


Preventing a COP time-out is done by writing a “0” to bit-O of address $1FFO. 
When the COP is cleared, only the final divide by eight stage (output of the RT]) is 
cleared. 


MFT REGISTERS 


Timer Counter Register (TCNT) $09 


The Timer Counter Register is a read-only register which contains the current 
value of the 8-bit ripple counter at the beginning of the timer chain. This counter is 
clocked at fop+4 and can be used for various functions including a software input 
capture. Extended time periods can be attained using the CTOF function to incre- 
ment a temporary RAM storage location thereby simulating a 16-bit (or more) 
counter. The value of each bit of the TCNT is shown in Figure 8-2. This register is 
cleared by reset. 
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BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT O 
TCNT R| TMR7 TMR6 TMR5 TMR4 TMR3 TMR2 TMR1 TMRO 
$0009 W 
reset: 0 0 0 0 0 0 0 0 


Figure 8-2. Timer Counter Register 


8.3.2 Timer Control/Status Register (TCSR) $08 


The TCSR contains the timer interrupt flag bits, the timer interrupt enable bits, and 
the real time interrupt rate select bits. Bit 2 and bit 3 are write-only bits which will 
read as logical zeros. Figure 8-3 shows the value of each bit in the TCSR follow- 


ing reset. 
BIT 7 BIT 6 BIT5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
TCSR R| CTOF RTIF 0 0 
CTOFE RTIE RT1 RTO 
$0008 W CTOFR RTIFR 
reset: 0 0 0 0 0 0 1 1 


Figure 8-3. Timer Control/Status Register (TCSR) 


RTO, RT1 — Real-Time Interrupt period select bits 
These two bits select the Real-Time Interrupt period and the COP Watchdog 
reset period. 


Table 8-1. RT| and COP Rates at fop=3.0MHz 


Bus Frequency, fgys=fop=3.0 MHz 

RT1 | RTO | Divide Ratio RTI Rate fOr ane is 
0 0 git 5.46ms 43.68ms 
0 1 215 10.92ms 87.36ms 
1 0 2i6 21.85ms 174.8ms 
1 1 ae 43.69ms 349.52ms 


RTIFR — Real Time Interrupt Acknowledge 
The RTIFR is an acknowledge bit that resets the RTIF flag bit. This bit is unaf- 
fected by reset. Reading the RTIFR will always return a logical zero. 
1= Clears the RTIF flag bit. 
0= Does not clear the RTIF flag bit. 


CTOFR — Timer Overflow Acknowledge 
The CTOFR is an acknowledge bit that resets the CTOF flag bit. This bit is 
unaffected by reset. Reading the CTOFR will always return a logical zero. 
1= Clears the CTOF flag bit. 
0= Does not clear the CTOF flag bit. 
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RTIE — Real Time Interrupt Enable 
The RTIE is an enable bit that allows generation of a TIMER Interrupt by the 
RTIF bit. 
1= When set, the TIMER Interrupt is generated when the RTIF flag bit is 
set. 
0= When cleared, no TIMER interrupt caused by RTIF bit set will be 
generated. This bit is cleared by reset. 


CTOFE — Timer Overflow Enable 
The CTOFE is an enable bit that allows generation of a TIMER Interrupt upon 
overflow of the Timer Counter Register. 
1= When set, the TIMER Interrupt is generated when the CTOF flag bit 
is set. 
0= When cleared, no TIMER interrupt caused by CTOF bit set will be 
generated. This bit is cleared by reset. 


RTIF — Real Time Interrupt Flag 
The RTIF is a read-only flag bit. 
1= Set when the output of the chosen (1 of 4 selections) Real Time 
Interrupt stage goes active. A TIMER Interrupt request will be 
generated if RTIE is also set. 
0= Reset by writing a logical one to the RTIF acknowledge bit, RTIFR. 
Writing to the RTIF flag bit has no effect on its value. This bit is 
cleared by reset. 


CTOF — Timer Overflow Flag 
The CTOF is a read-only flag bit. 
1= Set when the 8-bit ripple counter rolls over from $FF to $00. A 
TIMER Interrupt request will be generated if CTOFE is also set. 
0= Reset by writing a logical one to the CTOF acknowledge bit, 
CTOFR. Writing to the CTOF flag bit has no effect on its value. This 
bit is cleared by reset. 


8.4 OPERATION DURING STOP MODE 


When STOP is exited by an external interrupt or an LVR reset or an external 
RESET, the internal oscillator will resume, followed by a 224 or 4064 internal pro- 
cessor oscillator stabilization delay. 


8.5 COP CONSIDERATION DURING STOP MODE 


In STOP mode, the clock to the Watchdog Timer is stopped and is therefore 
impossible to generate COP reset when in STOP mode. The COP function will 
resume 224 or 4064 cycles after exiting from STOP. 
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SECTION 9 
16-BIT TIMER 


This 16-bit Programmable Timer (Timer1) has an Input Capture function and an 
Output Compare function. Figure 9-1 shows a block diagram of the 16-bit 
programmable timer. 


Zz 
SIGNAL 
SONDITIONING ICRH ($0014) | ICRL ($0015) 


ze 
TMRH ($0018) 


TCMPE 
(bit7 at $0E) 


IACRH ($001A)|ACRL ($001B) 


IEDG 


< INTERNAL 
16-BIT COUNTER +4 CLOCK 


(fosc + 2) 
PORT-C LOGIC 


16- R 
OCRH ($0016) | OCRL ($0017) 
PCO/ 


OVERFLOW (TOF) 


{OCF 


TIMER 
[tS De, 
REQUEST 
RESET + Cl} 
3] 3 © a 5 S| © 
$0072 $0013 
INTERNAL DATA BUS » i rl 
Figure 9-1. Programmable Timer Block Diagram 
MC68HCO5JB3 16-BIT TIMER MOTOROLA 
REV 1 9-1 


For More Information On This Product, 
Go to: www.freescale.com 


Freescale Semiconductor, Inc. 


GENERAL RELEASE SPECIFICATION November 5, 1998 


The basis of the 16-bit Timer is a 16-bit free-running counter which increases in 
count with each internal bus clock cycle. The counter is the timing reference for 
the input capture and output compare functions. The input capture and output 
compare functions provide a means to latch the times at which external events 
occur, to measure input waveforms, and to generate output waveforms and timing 
delays. Software can read the value in the 16-bit free-running counter at any time 
without affect the counter sequence. 


Because of the 16-bit timer architecture, the I/O registers for the input capture and 
output compare functions are pairs of 8-bit registers. Each register pair contains 
the high and low byte of that function. Generally, accessing the low byte of a spe- 
cific timer function allows full control of that function; however, an access of the 
high byte inhibits that specific timer function until the low byte is also accessed. 


Because the counter is 16 bits long and preceded by a fixed divide-by-four pres- 
caler, the counter rolls over every 262,144 internal clock cycles. Timer resolution 
with a 4MHz crystal oscillator is 2 microsecond/count. 


The interrupt capability, the input capture edge, and the output compare state are 
controlled by the timer control register (TCR) located at $0012 and the status of 
the interrupt flags can be read from the timer status register (TSR) located at 
$0013. 


9.1 TIMER REGISTERS (TMRH, TMRL) 
The functional block diagram of the 16-bit free-running timer counter and timer 
registers is shown in Figure 9-2. The timer registers include a transparent buffer 
latch on the LSB of the 16-bit timer counter. 
aN Bow 
CA 5 Ta 0) ——a— Fh 
READ | READ 
FFFC INTERNAL 
aa a r= — (glee 
(fosc + 2) 
OVERFLOW (TOF) TIMER 
+ | Da INTERRUPT 
REQUEST 
LL 
e eS 
$0012 $0013 
WW See INTERNAL 
DATA 
pat 
Figure 9-2. Programmable Timer Counter Block Diagram 
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The timer registers (TMRH, TMRL) shown in Figure 9-3 are read-only locations 
which contain the current high and low bytes of the 16-bit free-running counter. 
Writing to the timer registers has no effect. Reset of the device presets the timer 
counter to $FFFC. 


BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT O 
TMRH R) TMRH7 | TMRH6 | TMRH5 | TMRH4 | TMRH3 | TMRH2 | TMRH1 TMRHO 
$0018 W 
reset: 1 1 1 1 1 1 1 1 
TMRL R}| TMRL7 TMRL6 TMRL5 TMRL4 TMRL3 TMRL2 TMRL1 TMRLO 
$0019 W 
reset: 1 1 1 1 1 1 0 0 


Figure 9-3. Programmable Timer Counter Registers (TMRH, TMRL) 


The TMRL latch is a transparent read of the LSB until the a read of the TMRH 
takes place. A read of the TMRH latches the LSB into the TMRL location until the 
TMRL is again read. The latched value remains fixed even if multiple reads of the 
TMRH take place before the next read of the TMRL. Therefore, when reading the 
MSB of the timer at TMRH the LSB of the timer at TMRL must also be read to 
complete the read sequence. 


During power-on-reset (POR), the counter is initialized to $FFFC and begins 
counting after the oscillator start-up delay. Because the counter is sixteen bits and 
preceded by a fixed divide-by-four prescaler, the value in the counter repeats 
every 262, 144 internal bus clock cycles (524, 288 oscillator cycles). 


When the free-running counter rolls over from $FFFF to $0000, the timer overflow 
flag bit (TOF) is set in the TSR. When the TOF is set, it can generate an interrupt if 
the timer overflow interrupt enable bit (TOIE) is also set in the TCR. The TOF flag 
bit can only be reset by reading the TMRL after reading the TSR. 


Other than clearing any possible TOF flags, reading the TMRH and TMRL in any 
order or any number of times does not have any effect on the 16-bit free-running 
counter. 


NOTE 


To prevent interrupts from occurring between readings of the TMRH and TMRL, 
set the | bit in the condition code register (CCR) before reading TMRH and clear 
the | bit after reading TMRL. 
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9.2 


ALTERNATE COUNTER REGISTERS (ACRH, ACRL) 


The functional block diagram of the 16-bit free-running timer counter and alternate 
counter registers is shown in Figure 9-4. The alternate counter registers behave 
the same as the timer registers, except that any reads of the alternate counter will 
not have any effect on the TOF flag bit and Timer interrupts. The alternate counter 
registers include a transparent buffer latch on the LSB of the 16-bit timer counter. 


INTERNAL 
DATA 
BUS 


READ 
ACRL 


INTERNAL 
CLOCK 
(fosc + 2) 


Figure 9-4. Alternate Counter Block Diagram 


The alternate counter registers (ACRH, ACRL) shown in Figure 9-5 are read-only 
locations which contain the current high and low bytes of the 16-bit free-running 
counter. Writing to the alternate counter registers has no effect. Reset of the 
device presets the timer counter to $FFFC. 


BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
ACRH R| ACRH7 | ACRH6 ACRH5 ACRH4 | ACRH3 ACRH2 ACRH1 ACRHO 
$001A Ww 
reset: 1 1 1 1 1 1 1 1 


ACRL R| ACRL7 ACRL6 ACRL5 ACRL4 ACRL3 ACRL2 ACRL1 ACRLO 
$001B Ww 
reset: 1 1 1 1 1 1 0 0 


Figure 9-5. Alternate Counter Registers (ACRH, ACRL) 


The ACRL latch is a transparent read of the LSB until the a read of the ACRH 
takes place. A read of the ACRH latches the LSB into the ACRL location until the 
ACRL is again read. The latched value remains fixed even if multiple reads of the 
ACRH take place before the next read of the ACRL. Therefore, when reading the 
MSB of the timer at ACRH the LSB of the timer at ACRL must also be read to 
complete the read sequence. 


During power-on-reset (POR), the counter is initialized to $FFFC and begins 
counting after the oscillator start-up delay. Because the counter is sixteen bits and 
preceded by a fixed divide-by-four prescaler, the value in the counter repeats 
every 262,144 internal bus clock cycles (524,288 oscillator cycles). 


Reading the ACRH and ACRL in any order or any number of times does not have 
any effect on the 16-bit free-running counter or the TOF flag bit. 
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NOTE 


To prevent interrupts from occurring between readings of the ACRH and ACRL, 
set the | bit in the condition code register (CCR) before reading ACRH and clear 
the | bit after reading ACRL. 


9.3. INPUT CAPTURE REGISTERS 


INTERNAL 
DATA 
READ 2a~s oS BUS 
ICRH 
ICRH ($0014 
Sica CRH ($0014)| ICRL ($0 READ 
CONDITIONING 
INTERNAL 
5 16-BIT COUNTER CLOCK 
A) i INPUT CAPTURE (osc +2) 
a} i (ICF) 
TCMPE “| & TIMER 
(bit7 at $0E) eae peel 
a LL 
S S 
RESET TIMER CONTROL REG. TIMER STATUS REG. 


$0012 $0013 


INTERNAL 
DATA 
BUS 


Figure 9-6. Timer Input Capture Block Diagram 


The input capture function is a technique whereby an external signal (connected 
to PBO/TCAP pin) is used to trigger the 16-bit timer counter. In this way it is possi- 
ble to relate the timing of an external signal to the internal counter value, and 
hence to elapsed time. 


NOTE 


Since the TCAP pin is shared with the PBO I/O pin, changing the state of the PBO 
DDR or Data Register can cause an unwanted TCAP interrupt. This can be 
avoided by clearing the ICIE bit before changing the configuration of PBO, and 
clearing any pending interrupts before enabling ICIE. 


The signal on the TCAP pin is first directed to a schmitt trigger or a voltage 
comparator as shown in Figure 9-7. Setting the TCMPE bit to “1” will enable the 
comparator and the Vpp/2 reference voltage. 
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BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
OIER R 
TCMPE VREF2 VREF1 VREFO OIE3 OIE2 OIE1 OIEO 
$000E WwW 
reset: 0 0 0 0 0 0 0 0 


TCMPE — Timer Input Capture Comparator Enable 
1 = Timer input capture comparator is selected. 
O0= Timer input capture comparator schmitt trigger is selected. 


NOTE 


When the comparator and Vpp/2 reference are enabled, PBO pin will automatically 
becomes an input pin, irrespective of DDR setting. However, it is recommended to 
set PBO as an input first (via DDR), before enabling the comparator. A read of PBO 
will reflect the TCAP pin status, not the PBO register bit. 


The comparator uses the Vpp/2 reference as the compare voltage, resulting in a 
typical output as shown in Figure 9-8. 


Switching off the Vpp/2 voltage reference by clearing TCMPE=0 will further save 
power when the MCU is in a low power mode. 


PBO/ PBO I/O 
TCAP PORT LOGIC 


Schmitt Trigger 


rr 


Voltage To edge select and 
Reference Comparator detect logic 
VREF > 
EN TCMPE bit 
Figure 9-7. TCAP Input Signal Conditioning 
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Output of Comparator 


Vop BS SS Se REE ESS 
Signal on TCAP pin 


Time 


Figure 9-8. TCAP Input Comparator Output 


When the input capture circuitry detects an active edge on the TCAP pin, it 
latches the contents of the free-running timer counter registers into the input cap- 
ture registers as shown in Figure 9-6. 


Latching values into the input capture registers at successive edges of the same 
polarity measures the period of the selected input signal. Latching the counter val- 
ues at successive edges of opposite polarity measures the pulse width of the sig- 
nal. 


The input capture registers are made up of two 8-bit read-only registers (ICRH, 
ICRL) as shown in Figure 9-9. The input capture edge detector contains a Schmitt 
trigger to improve noise immunity. The edge that triggers the counter transfer is 
defined by the input edge bit (IEDG) in the TCR. Reset does not affect the con- 
tents of the input capture registers. 


The result obtained by an input capture will be one count higher than the value of 
the free-running timer counter preceding the external transition. This delay is 
required for internal synchronization. Resolution is affected by the prescaler, 
allowing the free-running timer counter to increment once every four internal clock 
cycles (eight oscillator clock cycles). 


BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
ICRH R| ICRH7 ICRH6 ICRH5 ICRH4 ICRH3 ICRH2 ICRH1 ICRHO 
$0014 W 
reset: U U U U U U U U 
ICRL R}| ICRL7 ICRL6 ICRL5 ICRL4 ICRL3 ICRL2 ICRL1 ICRLO 
$0015 W 
reset: U U U U U U U U 


U = UNAFFECTED BY RESET 
Figure 9-9. Input Capture Registers (ICRH, ICRL) 
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9.4 


Reading the ICRH inhibits further captures until the ICRL is also read. Reading 
the ICRL after reading the timer status register (TSR) clears the ICF flag bit. does 
not inhibit transfer of the free-running counter. There is no conflict between read- 
ing the ICRL and transfers from the free-running timer counters. The input capture 
registers always contain the free-running timer counter value which corresponds 
to the most recent input capture. 


NOTE 


To prevent interrupts from occurring between readings of the ICRH and ICRL, set 
the | bit in the condition code register (CCR) before reading ICRH and clear the 
| bit after reading ICRL. 


OUTPUT COMPARE REGISTERS 


The Output Compare function is a means of generating an interrupt when the 16- 
bit timer counter reaches a selected value as shown in Figure 9-10. Software 
writes the selected value into the output compare registers. On every fourth inter- 
nal clock cycle (every eight oscillator clock cycle) the output compare circuitry 
compares the value of the free-running timer counter to the value written in the 
output compare registers. When a match occurs, the output compare interrupt 
flag, OCF is set. A timer interrupt request to the CPU is generated if the output 
compare interrupt enable is set, i.e. OCIE=1. 


Port pin, PCO is configured as the OCMP output pin when the OCMPO bit (bit7 at 
$06) is set to “1”. The OCMP output reflects the logic of the output compare inter- 
rupt flag, OCF, as shown in Figure 9-10. 


BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 


DDRC R 
$0006 Ww 
reset: 0 0 0 0 0 0 0 0 


OCMPO | VROFF DDRC3 | DDRC2 | DDRC1 DDRCO 


OCMPO — OCMP Output Enable 
1= PCO is OCMP pin, OCF from 16-bit timer output compare. 
0= PCO is standard I/O pin, from Port-C data register. 


Software can use the output compare register to measure time periods, to gener- 
ate timing delays, or to generate a pulse of specific duration or a pulse train of 
specific frequency and duty cycle. 


Writing to the OCRH before writing to the OCRL inhibits timer compares until the 
OCRL is written. Reading or writing to the OCRL after reading the TSR will clear 
the output compare flag bit (OCF). 
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PORT-C LOGIC 
aS Zs OCMPO (bit7 at $06) 
R/W 
OCRH OCRH ($0016) OCRL ($0017) 
($FFFC) INTERNAL 
| (fosc + 2) 
OUTPUT COMPARE 
if Seda | INTERRUPT 
REQUEST 
$0012 
C » INTERNAL 
DATA 
BUS 
Figure 9-10. Timer Output Compare Block Diagram 
BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
OCRH JR 
so01e fw) CORK? | OCRH6 | OCRHS | OCRH4 | OCRH3 / OCRH2 | OCRHt | OCRHO 
reset: U U U U U U U U 
OcRL BI ocrt7 | ocrts | ocrts | ocrt4 | ocrts | ocrte | ocrLi | ocALo 
$0017 W 
reset: U U U U U U U U 
U = UNAFFECTED BY RESET 
Figure 9-11. Output Compare Registers (OCRH, OCRL) 
To prevent OCF from being set between the time it is read and the time the output 
compare registers are updated, use the following procedure: 
1. Disable interrupts by setting the | bit in the condition code register. 
2. Write to the OCRH. Compares are now inhibited until OCRL is written. 
3. Read the TSR to arm the OCF for clearing. 
4. Enable the output compare registers by writing to the OCRL. This also 
clears the OCF flag bit in the TSR. 
5. Enable interrupts by clearing the | bit in the condition code register. 
A software example of this procedure is shown below. 
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9B SEI DISABLE INTERRUPTS 

B7 16 STA OCRH INHIBIT OUTPUT COMPARE 

B6 13 LDA TSR ARM OCF FLAG FOR CLEARING 

BF 17 STX OCRL READY FOR NEXT COMPARE, OCF CLEARED 
9A CLI ENABLE INTERRUPTS 


9.5 TIMER CONTROL REGISTER (TCR) 


The timer control register is shown in Figure 9-12 performs the following func- 
tions: 


¢ Enables input capture interrupts 

¢ Enables output compare interrupts 

¢ Enables timer overflow interrupts 

¢ Control the active edge polarity of the TCAP signal on pin PBO/TCAP 
Reset clears all the bits in the TCR with the exception of the IEDG bit which is 


unaffected. 
BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT O 
TCR R 0 0 
. —  ICIE OCIE TOIE SSS a a Ce (Se IEDG 9-—— 
$0012 Ww 
reset: 0 0 0 0 0 0 Unaffected 0 


Figure 9-12. Timer Control Register (TCR) 


ICIE - INPUT CAPTURE INTERRUPT ENABLE 
This read/write bit enables interrupts caused by an active signal on the PBO/ 
TCAP pin. Reset clears the ICIE bit. 
1 = Input capture interrupts enabled. 
0 = Input capture interrupts disabled. 


OCIE - OUTPUT COMPARE INTERRUPT ENABLE 
This read/write bit enables interrupts caused by a successful compare between 
the timer counter and the output compare registers. Reset clears the OCIE bit. 
1 = Output compare interrupts enabled. 
0= Output compare interrupts disabled. 


TOIE - TIMER OVERFLOW INTERRUPT ENABLE 
This read/write bit enables interrupts caused by a timer overflow. Reset clears 
the TOIE bit. 
1= Timer overflow interrupts enabled. 
0= Timer overflow interrupts disabled. 
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IEDG - INPUT CAPTURE EDGE SELECT 
The state of this read/write bit determines whether a positive or negative transi- 
tion on the TCAP pin triggers a transfer of the contents of the timer register to 
the input capture register. Reset has no effect on the IEDG bit. 
1= Positive edge (low to high transition) triggers input capture. 
0= Negative edge (high to low transition) triggers input capture. 


9.6 TIMER STATUS REGISTER (TSR) 


The timer status register (TSR) shown in Figure 9-13 contains flags for the follow- 
ing events: 


* An active signal on the PBO/TCAP pin, transferring the contents of the 
timer registers to the input capture registers. 


¢ Amatch between the 16-bit counter and the output compare registers 
* An overflow of the timer registers from $FFFF to $0000. 


Writing to any of the bits in the TSR has no effect. Reset does not change the 
state of any of the flag bits in the TSR. 


BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
TSR R ICF OCF TOF 0 0 0 0 0 
$0013 W 
reset: U U U 0 0 0 0 0 


U = UNAFFECTED BY RESET 
Figure 9-13. Timer Status Registers (TSR) 


ICF - INPUT CAPTURE FLAG 
The ICF bit is automatically set when an edge of the selected polarity occurs on 
the PBO/TCAP pin. Clear the ICF bit by reading the timer status register with 
the ICF set, and then reading the low byte (ICRL, $0015) of the input capture 
registers. Reset has no effect on ICF. 


OCF - OUTPUT COMPARE FLAG 
The OCF bit is automatically set when the value of the timer registers matches 
the contents of the output compare registers. Clear the OCF bit by reading the 
timer status register with the OCF set, and then accessing the low byte (OCRL, 
$0017) of the output compare registers. Reset has no effect on OCF. 
OCF status will be latched to the output of OCMP (PCO pin) if the OCMPO bit is 
set to “1” (bit7 at $06). 


TOF - TIMER OVERFLOW FLAG 
The TOF bit is automatically set when the 16-bit timer counter rolls over from 
$FFFF to $0000. Clear the TOF bit by reading the timer status register with the 
TOF set, and then accessing the low byte (TMRL, $0019) of the timer registers. 
Reset has no effect on TOF. 
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9.7 


9.8 


TIMER OPERATION DURING WAIT MODE 


During WAIT mode the 16-bit timer continues to operate normally and may gener- 
ate an interrupt to trigger the MCU out of the WAIT mode. 


TIMER OPERATION DURING STOP MODE 


When the MCU enters the STOP mode the free-running counter stops counting 
(the internal processor clock is stopped). It remains at that particular count value 
until the STOP mode is exited by applying a low signal to the IRQ pin, at which 
time the counter resumes from its stopped value as if nothing had happened. If 
STOP mode is exited via an external reset (logic low applied to the RESET pin) 
the counter is forced to $FFFC. 


If a valid input capture edge occurs at the PBO/TCAP pin during the STOP mode 
the input capture detect circuitry will be armed. This action does not set any flags 
or “wake up” the MCU, but when the MCU does “wake up” there will be an active 
input capture flag (and data) from the first valid edge. If the STOP mode is exited 
by an external reset, no input capture flag or data will be present even if a valid 
input capture edge was detected during the STOP mode. 
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SECTION 10 
UNIVERSAL SERIAL BUS MODULE 


This USB Module is designed for USB application in LS products. With minimized 
software effort, it can fully comply with USB LS device specification. See USB 
specification version 1.0 for the detail description of USB. 
10.1 FEATURES 
¢ Integrated 3.3 Volt Regulator with 3.3V Output Pin 
¢ Integrated USB transceiver supporting Low Speed functions 
¢ USB Data Control Logic 
— Packet decoding/generation 
— CRC generation and checking 
— NRZI encoding/decoding 


Bit-stuffing 

¢ USB reset support 

* Control Endpoint 0 and Interrupt Endpoints 1 and 2 
* Two 8-byte transmit buffers 

¢* One 8-byte receive buffer 

* Suspend and resume operations 

¢ Remote Wake-up support 

¢ USB generated interrupts 

¢ Transaction interrupt driven 

¢« Resume interrupt 

¢ End of Packet interrupt 

¢ STALL, NAK, and ACK handshake generation 
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10.2 OVERVIEW 


This section provides an overview of the Universal Serial Bus (USB) module in the 
MC68HCO5UB3. This USB module is designed to serve as a low-speed (LS) USB 
device per the Universal Serial Bus Specification Rev 1.0. Three types of USB 
data transfers are supported: control, interrupt, and bulk (transmit only). 
Endpoint 0 functions as a receive/transmit control endpoint. Endpoints 1 and 2 
can function as interrupt or bulk, but only in the transmit direction. 


A block diagram of the USB module is shown Figure 10-1. The USB module 
manages communications between the host and the USB function. The module is 
partitioned into four functional blocks. These blocks consist of a 3.3 volt regulator, 
a dual function transceiver, the USB control logic, and the endpoint registers. The 
blocks are further detailed in Section 10.4. 
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Figure 10-1. USB Block Diagram 
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10.2.1 USB Protocol 


Figure 10-2. shows the various transaction types supported by _ the 
MC68HCO05JB3 USB module. The transactions are portrayed as error free. The 
effect of errors in the data flow are discussed later. 


ENDPOINT 0 TRANSACTIONS: 


Control Write 
SETUP DATAO ACK Res OUT | DATA1 | ACK Sooo 
fo a ete ee ae 
ae OUT DATAO ACK i esseseees OUT DATAO/1 ACK 


Control Read 


el IN DATAO ACK reeseseees IN DATAO/1 ACK 


> BESS OUT DATA1 ACK 
No-Data Control 
SETUP DATAO ACK SSS IN | DATA1 | ACK | 


ENDPOINTS 1 & 2 TRANSACTIONS: 


KEY: 
Interrupt 
Unrelated Bus 
IN DATAO/1 | ACK | Traffic 
Host 
Bulk Transmit Generated 
Device 
IN DATAO/1 | ACK | Generated 


Figure 10-2. Supported Transaction Types per Endpoint 


Each USB transaction is comprised of a series of packets. The MC68HC05JB3 
USB module supports the packet types shown in Figure 10-3. Token packets are 
generated by the USB host and decoded by the USB device. Data and 
Handshake packets are both decoded and generated by the USB device 
depending on the type of transaction. 
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Token Packet: 
IN 
OUT SYNC PID PID ADDR | ENDP | CRC5 EOP 


SETUP 

Data Packet: 
DATAO SYNC PID Pl DATA CRC5 EOP 
DATA1 0 - 8 bytes 


Handshake Packet: 
ACK 
NAK SYNC PID PID EOP 
STALL 


Figure 10-3. Supported USB Packet Types 


The following sections will give some detail on each segment used to form a 
complete USB transaction. 


10.2.1.1 Sync Pattern 


The NRZI (See Section 10.4.4.1) bit pattern shown in Figure 10-4 is used as a 
synchronization pattern and is prefixed to each packet. This pattern is equivalent 
to a data pattern of seven 0’s followed by a 1 (0x80). 


SYNC PATTERN 


« > 
‘emecing <4 \_f\_f \__[\__[Poo(rony 


Figure 10-4. Sync Pattern 


The start of a packet (SOP) is signaled by the originating port by driving the D+ 
and D- lines from the idle state (also referred to as the “J” state) to the opposite 
logic level (also referred to as the “K” state). This switch in levels represents the 
first bit of the Sync field. Figure 10-5 shows the data signaling and voltage levels 
for the start of packet and the sync pattern. 
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Vge (min) 


BUS IDLE SOP END OF SYNC 


Figure 10-5. SOP, Sync Signaling and Voltage Levels 


10.2.1.2 Packet Identifier Field 


The Packet Identifier field is an eight bit number comprised of the four bit packet 
identification (PID) and its complement. The field follows the sync pattern and 
determines the direction and type of transaction on the bus. Table 10-1 shows the 
PID values for the supported packet types. 


Table 10-1. Supported Packet Identifiers 


PID Value PID Type 
%1001 IN Token 
%0001 OUT Token 
%1101 SETUP Token 
%001 1 DATAO Packet 
%1011 DATA1 Packet 
%0010 ACK Handshake 
%1010 NAK Handshake 
%1110 STALL Handshake 


10.2.1.3 Address Field (ADDR) 


The Address field is a seven bit number that is used to select a particular USB 
device. This field is compared to the lower seven bits of the UADDR register to 
determine if a given transaction is targeting the MC68HCO5JB3 USB device. 
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10.2.1.4 Endpoint Field (ENDP) 


The Endpoint field is a four bit number that is used to select a particular endpoint 
within a USB device. For the MC68HCO5JB3, this will be a binary number 
between zero and two inclusive. Any other value will cause the transaction to be 
ignored. 


10.2.1.5 Cyclic Redundancy Check (CRC) 


Cyclic Redundancy Checks are used to verify the address and data stream of a 
USB transaction. This field is five bits wide for token packets and sixteen bits wide 
for data packets. CRCs are generated in the transmitter and sent on the USB data 
lines after both the endpoint field and the data field. Figure 10-6 shows how the 
five bit CRC value is calculated from the data stream and verified for the address 
and endpoint fields of a token packet. Figure 10-7 shows how the sixteen bit CRC 
value is calculated and either transmitted or verified for the data packet of a given 
transaction. 


Update every bit time Generator Polynomial: 
Reset to ones at SOP ojo] of 4 


Data Stream 


ROT | next bit 
elle 


Expected Residual: 
0/1/1)0)0 
5 


2? 
Good CRC g . Bad CRC 


Figure 10-6. CRC Block Diagram for Address and Endpoint Fields 
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Update every bit time Generator Polynomial: 
Reset to ones at SOP 1]0/0]0]0]0JoJo]ojoofolo|1 oft 
Input / Output 
Data Stream 16 
next bit | | | | gO) 
| 16 
0 mux | 
Output TRANSMIT 16 
Data Stream 
; 16 
CRC16 Transmitted 
MSB first after final 
data byte. RECEIVE Expected Residual: 
1]0}0}0}0/0/0/0)0j0}0/0}1}1)0}1 


16 


Good CRC }«——{_ Equal?) >| Bad CRC 
_ N 


Figure 10-7. CRC Block Diagram for Data Packets 


10.2.1.6 End Of Packet (EOP) 


The single-ended 0 (SEO) state is used to signal an end of packet (EOP). The 
single-ended 0 state is indicated by both D+ and D-— being below 0.8 V. EOP will 
be signaled by driving D+ and D-— to the single-ended 0 state for two bit times 
followed by driving the lines to the idle state for one bit time. The transition from 
the single-ended 0 to the idle state defines the end of the packet. The idle state is 
asserted for one bit time and then both the D+ and D- output drivers are placed in 
their high-impedance state. The bus termination resistors hold the bus in the idle 
state. Figure 10-8 shows the data signaling and voltage levels for an end of 
packet transaction. 
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cee BUS DRIVEN TO 
EOP IDLE STATE 
STROBE eee 
BUS IDLE 


Vow (min) ----|Jf--FR--------t-F-44--)W------|Jf----------- 


Figure 10-8. EOP Transaction Voltage Levels 


The width of the SEO in the EOP is about two bit times. The EOP width is 
measured with the same capacitive load used for maximum rise and fall times and 
is measured at the same level as the differential signal crossover points of the 
data lines. 


tPeriod < > | 


DIFFERENTIAL ee 


DATA LINES 


DATA 
CROSSOVER 
LEVEL 


~~ 


|e EOP > 


WIDTH 


Figure 10-9. EOP Width Timing 


10.2.2 Reset Signaling 


A reset is signaled on the bus by the presence of an extended SEO at the USB 
data pins of a device. The reset signaling is specified to be present for a minimum 
of 10 ms. An active device (powered and not in the suspend state) seeing a 
single-ended zero on its USB data inputs for more than 2.5uUs may treat that signal 
as a reset, but must have interpreted the signaling as a reset within 5.5 Us. For a 
Low speed device, an SEO condition between 4 and 8 low speed bit times 
represents a valid USB reset. 


A USB sourced reset will hold the MC68HCO5JB3 in reset for the duration of the 
reset on the USB bus. The RSTF bit in the USB interrupt register 0 (UIRO) will be 
set after the internal reset is removed (See Section 10.5.2 for more detail). 


After a reset is removed, the device will be in the attached, but not yet addressed 
or configured state (refer to Section 9.1 of the USB specification). The device must 
be able to accept a device address via a SET_ ADDRESS command (refer to 
section 9.4 of the USB specification) no later than 10 ms after the reset is 
removed. 
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Reset can wake a device from the suspended mode. A device may take up to 
10ms to wake up from the suspended state. 


10.2.3 Suspend 


The MC68HCO5JB3 supports suspend mode for low power. Suspend mode 
should be entered when the USB data lines are in the idle state for more than 3.0 
ms. Entry into Suspend mode is controlled by the SUSPND bit in the USB 
Interrupt Register. Any low speed bus activity should keep the device out of the 
suspend state. Low speed devices are kept awake by periodic low speed EOP 
signals from the host. This is referred to as Low speed keep alive (refer to Section 
11.2.5.1 of the USB specification). 


Firmware should monitor the EOPF flag and enter suspend mode by setting the 
SUSPND bit if an EOP is not detected for 3 ms. 


Per the USB specification, the MC68HCO5JB3 is required to draw less than 
500A from the Vpp supply when in the suspend state. This includes the current 
supplied by the voltage regulator to the 15 KQ to ground termination resistors 
placed at the host end of the USB bus. This low current requirement means that 
firmware is responsible for entering STOP mode once the USB module has been 
placed in the suspend state. 


10.2.4 Resume After Suspend 


The MC68HCO05JB3 can be activated from the suspend state by normal bus 
activity, a USB reset signal, or by a forced resume driven from the 
MC68HCO5JB3. 


10.2.4.1 Host Initiated Resume 


The host signals resume by initiating resume signalling (“K” state) for at least 20 
ms followed by a standard low speed EOP signal. This 20 ms ensures that all 
devices in the USB network are awakened. 


After resuming the bus, the host must begin sending bus traffic within 3 ms to 
prevent the device from re-entering suspend mode. 


10.2.4.2 USB Reset Signalling 


Reset can wake a device from the suspended mode. A device may take up to 10 
ms to wake up from the suspended state. 


10.2.4.3 Remote Wake-up 


The MC68HCO05JB3 also supports the remote wake-up feature. The firmware has 
the ability to exit suspend mode by signaling a resume state to the upstream Host 
or Hub. A non-idle state (“K” state) on the USB data lines is accomplished by 
asserting the FRESUM bit in the UCR1 register. 
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When using the remote wake-up capability, the firmware must wait for at least 5 
ms after the bus is in the idle state before sending the remote wake-up resume 
signaling. This allows the upstream devices to get into their suspend state and 
prepare for propagating resume signaling. The FRESUM bit should be asserted to 
cause the resume state on the USB data lines for at least 10ms, but not more than 
15ms. Note that the resume signalling is controlled by the FRESUM bit and 
meeting the timing specifications is dependent on the firmware. When FRESUM is 
cleared by firmware, the data lines will return to their high impedance state. Refer 
to Section 10.5.5 for more information about how the Force Resume (FRESUM) 
bit can be used to initiate the remote wake-up feature. 


10.2.5 Low Speed Device 


10.3 


10.4 


Externally, low speed devices are configured by the position of a pull-up resistor 
on the USB D- pin of the MC68HCO5JB3. Low speed devices are terminated as 
shown in Figure 10-10 with the pull-up on the D- line. 


3.3V Regulator Out 


MC68HCO05JB3 1.5KQ 


D+ 
USB Low Speed Cable 
D- 


Figure 10-10. External Low Speed Device Configuration 


For low speed transmissions, the transmitters EOP width must be between 
1.25us and 1.50us. These ranges include timing variations due to differential 
buffer delay and rise/fall time mismatches and to noise and other random effects. 
A low speed receiver must accept a 670ns wide SEO followed by a J transition as 
a valid EOP. An SEO narrower than 330ns or an SEO not followed by a J transition 
must be rejected as an EOP. An EOP between 330ns and 670ns may be rejected 
or accepted as above. Any SEO that is 2.5us or wider is automatically a reset. 


CLOCK REQUIREMENTS 


The low speed data rate is nominally 1.5 Mbps. The OSCXCLK signal driven by the 
oscillator circuits is the clock source for the USB module and requires that a 6 
MHz oscillator circuit be connected to the OSC1 and OSC2 pins. The permitted 
frequency tolerance for low speed functions is approximately +1.5% (15000 ppm). 
This tolerance includes inaccuracies from all sources: initial frequency accuracy, 
crystal capacitive loading, supply voltage on the oscillator, temperature, and 
aging. The jitter in the low speed data rate must be less than 10 ns. This tolerance 
allows the use of resonators in low cost, low speed devices. 


HARDWARE DESCRIPTION 


The USB module as previously shown in Figure 10-1 contains four functional 
blocks: a 3.3 volt regulator, a LS USB transceiver, the USB control logic, and the 
USB registers. The following will detail the function of the regulator, transceiver 
and control logic. See Section 10.5 for the register discussion. 
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10.4.1 Voltage Regulator 


The USB data lines are required by the USB Specification to have a maximum 
output voltage between 2.8V and 3.6V. The data lines are also required to have an 
external 1.5KQ pullup resistor connected between a data line and a voltage 
source between 3.0V and 3.6V. Since the power provided by the USB cable is 
specified to be between 4.4V and 5.0V, an on-chip regulator is used to drop the 
voltage to the appropriate level for sourcing the USB transceiver and external 
pullup resistor. An output pin driven by the regulator voltage is provided to source 
the 1.5KQ external resistor. Figure 10-11 shows the worst case electrical 
connection for the voltage regulator. 


This regulator can be switched off by user program to save power when the device 
is in suspend mode. Please note that if the regulator is off, the D- line should be 
tied to another voltage source with an external pull-up resistor. 


BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
DPA 2 OCMPO | VROFF DDRC3 DDRC2 DDRC1 DDRCO 
$0006 Ww 
reset: 0 0 0 0 0 0 0 0 


VROFF — USB 3.3V Voltage Reference 
The 3.3V Voltage Regulator for the USB transmitter and external D— pull-up can 
be switched off to reduce power consumption when device is in suspend mode. 
1= Disable 3.3V regulator. 
0= Enables 3.3V regulator. 


4.4V 


VROFF 


USB Data Lines 


mee Tee. ee 
USB Cable ‘| t or 
Transceiver _| ey i Hub 
a R2 
R1 = 1.5KQ +5% 
R2 = 15KQ +5% 
Figure 10-11. Regulator Electrical Connections 
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10.4.2 USB Transceiver 


The USB transceiver provides the physical interface to the USB D+ and D- data 
lines. The transceiver is composed of two parts: an output drive circuit and a 
differential receiver. 


10.4.2.1 Output Driver Characteristics 


The USB transceiver uses a differential output driver to drive the USB data signal 
onto the USB cable. The static output swing of the driver in its low state is below 
the Vo, of 0.3 V with a 1.5 kQ load to 3.6 V and in its high state is above the Voy 
of 2.8 V with a 15 kQ load to ground. The output swings between the differential 
high and low state are well balanced to minimize signal skew. Slew rate control on 
the driver is used to minimize the radiated noise and cross talk. The driver’s 
outputs support three-state operation to achieve bi-directional half duplex 
operation. The driver can tolerate a voltage on the signal pins of —0.5 V to 3.8 V 
with respect to local ground reference without damage. 


10.4.2.2 Low Speed (1.5 Mbs) Driver Characteristics 


The rise and fall time of the signals on this cable are greater than 75 ns to keep 
RFI emissions under FCC class B limits, and less than 300 ns to limit timing 
delays and signaling skews and distortions. The driver reaches the specified static 
signal levels with smooth rise and fall times, and minimal reflections and ringing 
when driving the cable. This driver is used only on network segments between low 
speed devices and the ports to which they are connected. 


ONE BIT 
<t— TIME ——> 
(1.5 Mb/s) 


SIGNAL PINS 


MSE AMERL Sete Tere == 'S* PASS OUTPUTSPEG P= Vo se 
LEVELS WITH MINIMAL 
REFLECTIONS AND RINGING 
Vge (min) we ee a 


Figure 10-12. Low Speed Driver Signal Waveforms 


10.4.3 Receiver Characteristics 


USB data transmission is done with differential signals. A differential input receiver 
is used to accept the USB data signal. A differential 1 on the bus is represented by 
D+ being at least 200 mV more positive than D- as seen at the receiver, and a 
differential 0 is represented by D— being at least 200 mV more positive than D+ as 
seen at the receiver. The signal cross over point must be between 1.3V and 2.0V. 
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The receiver features an input sensitivity of 200 mV when both differential data 
inputs are in the range of 0.8 V to 2.5 V with respect to the local ground reference. 
This is called the common mode input voltage range. Proper data reception is also 
achieved when the differential data lines are outside the common mode range, as 
shown in Figure 10-13. The receiver can tolerate static input voltages between 
—0.5V to 3.8 V with respect to its local ground reference without damage. In 
addition to the differential receiver, there is a single-ended receiver (schmitt 
trigger) for each of the two data lines. 


10%-------- ee ee He ee ee ee ee ee ee ee ee ee eee eee ae 


08 4 
0.6 + 
04+ 


(eee pees 


MINIMUM DIFFERENTIAL SENSITIVITY (VOLTS) 


02 04 06 08 10 12 14 16 18 20 22 24 26 28 30 32 


COMMON MODE INPUT VOLTAGE (VOLTS) 


Figure 10-13. Differential Input Sensitivity Over Entire Common Mode Range 


10.4.3.1 Receiver Data Jitter 


The data receivers for all types of devices must be able to properly decode the 
differential data in the presence of jitter. The more of the bit cell that any data edge 
can occupy and still be decoded, the more reliable the data transfer will be. Data 
receivers are required to decode differential data transitions that occur in a 
window plus and minus a nominal quarter bit cell from the nominal (centered) data 
edge position. 


Jitter will be caused by the delay mismatches and by mismatches in the source 
and destination data rates (frequencies). The receive data jitter budget for low 
speed is given in the electrical section of the this specification. The specification 
includes the consecutive (next) and paired transition values for each source of 
jitter. 


10.4.3.2 Data Source Jitter 


The source of data can have some variation (jitter) in the timing of edges of the 
data transmitted. The time between any set of data transitions is 
N x TpeRiop = jitter time, where ‘N’ is the number of bits between the transitions 
and Tperiop is defined as the actual period of the data rate. The data jitter is 
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measured with the same capacitive load used for maximum rise and fall times and 
is measured at the crossover points of the data lines as shown in Figure 10-14. 


aoa a or ot ok ow ot hr 


CROSSOVER 
DIFFERENTIAL is POINTS 


DATA LINES ‘ 


CONSECUTIVE 
TRANSITIONS 


PAIRED 
TRANSITIONS 


Figure 10-14. Data Jitter 


For low speed transmissions, the jitter time for any consecutive differential data 
transitions must be within +25 ns and within +10 ns for any set of paired 
differential data transitions. These jitter numbers include timing variations due to 
differential buffer delay, rise/fall time mismatches, internal clock source jitter, and 
to noise and other random effects. 


10.4.3.3 Data Signal Rise and Fall Time 


The output rise time and fall time are measured between 10% and 90% of the 
signal. Edge transition time for the rising and falling edges of low speed signals is 
75 ns (minimum) into a capacitive load (C,_) of 50 pF and 300 ns (maximum) into a 
capacitive load of 350 pF. The rising and falling edges should be smooth 
transitional (monotonic) when driving the cable to avoid excessive EMI. 


RISE TIME FALL TIME 


Val 90% 90% 
C CL DIFFERENTIAL 


DATA LINES 


ARC, 


LOW SPEED: 75 ns at C, = 50 pF, 300 ns at C, = 350 pF 


Figure 10-15. Data Signal Rise and Fall Time 


10.4.4 USB Control Logic 


The USB control logic manages data movement between the CPU and the 
transceiver. The control logic handles both transmit and receive operations on the 
USB. It contains the logic used to manipulate the transceiver and the endpoint 
registers. The logic contains byte count buffers for transmit operations that load 
the active transmit endpoints byte count and use this to determine the number of 
bytes to transfer. This same buffer is used for receive transactions to count the 
number of bytes received and, upon the end of the transaction, transfer that 
number to the receive endpoints byte count register. 
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When transmitting, the control logic handles parallel to serial conversion, CRC 
generation, NRZI encoding, and bit stuffing. 


When Receiving, the control logic handles Sync detection, packet identification, 
end of packet detection, bit (un)stuffing, NRZI decoding, CRC validation, and 
serial to parallel conversion. Errors detected by the control logic include bad CRC, 
time-out while waiting for EOP, and bit stuffing violations. 


10.4.4.1 Data Encoding/Decoding 


The USB employs NRZI data encoding when transmitting packets. In NRZI 
encoding, a 1 is represented by no change in level and a 0 is represented by a 
change in level. Figure 10-16 shows a data stream and the NRZI equivalent and 
Figure 10-17 is a flow diagram for NRZI. The high level represents the J state on 
the data lines in this and subsequent figures showing NRZI encoding. A string of 
zeros causes the NRZI data to toggle each bit time. A string of ones causes long 
periods with no transitions in the data. 


0 1 141 0 141 0 14 0 0 0 1 0 0 4 +14 = 0 


DATA IDLE | | | | | | | | | | | 


NRZI IDLE 


Figure 10-16. NRZI Data Encoding 
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Figure 10-17. Flow Diagram for NRZI 
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10.4.4.2 Bit Stuffing 


In order to ensure adequate signal transitions, bit stuffing is employed by the 
transmitting device when sending a packet on the USB (see Figure 10-18 and 
Figure 10-19). A 0 is inserted after every six consecutive 1’s in the data stream 
before the data is NRZI encoded to force a transition in the NRZI data stream. 
This gives the receiver logic a data transition at least once every seven bit times to 
guarantee the data and clock lock. The receiver must decode the NRZI data, 
recognize the stuffed bits, and discard them. Bit stuffing is enabled beginning with 
the Sync Pattern and throughout the entire transmission. The data “one” that ends 
the Sync Pattern is counted as the first one in a sequence. Bit stuffing is always 
enforced, without exception. If required by the bit stuffing rules, a zero bit will be 
inserted even if it is the last bit before the end-of-packet (EOP) signal. 
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J STUFFED BIT 
aT a eee tem 
STUFFED l~— SYNC PATTERN alae PACKET DATA. >| 
DATA 


SIX ONES 7] 


NRZI 
ENCODED IDLE 


DATA |< SYNC PATTERN |< PACKET DATA ——____»| 


Figure 10-18. Bit Stuffing 
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Figure 10-19. Flow Diagram for Bit Stuffing 
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10.5 I/O REGISTER DESCRIPTION 


The USB Endpoint registers are comprised of a set of control/status registers and 
twenty-four data registers that provide storage for the buffering of data between 
the USB and the CPU. These registers are shown in Table 10-2. 


Table 10-2. Register Summary 


Register Name Bit 7 6 5 4 3 2 1 BitO Addr 
| 0 | TXiST 

gee eee ENABLE2|ENABLE1| STALL2 | STALLt | $0037 
(UCR) TXISTR 

Eee vo EB USBEN | UADD6 | UADDS | UADD4 | UADD3 | UADD2 | UADD1 | UADDO | $0038 
| TXDOF | RXDOF | RSTF 0 0 

USB Interrupt Register 0 SUSPND | TXDOIE | RXDOIE $0039 
eee TXDOFR | RXDOFR 
| TXDIF | EOPF |RESUMF| 0 0 0 

USB Interrupt Register 1 TxDIIE | EOPIE san 
(UIR1) RESUMFR TXD1FR | EOPFR 

apne: cca TOSEQ | STALLO] TXOE | RXOE | TPOSIZ3 | TPOSIZ2 | TPOSIZ! | TPOSIZO | $003B 

coe bie TISEQ |ENDADD] TX1E | FRESUM | TP1SIz3 | TP1SIZ2 | TP1SIZt | TP1SIZO | $003C 

USB Status Register| SEQ | SETUP | 0 0 | RPsiz3 | RPSiz2 | RPSIZt | RPSIZo 

(USR) $003D 


USB Endpoint 0 Data) UEORD7 | UEORD6 | UEORDS | UEORD4 | UEORDS | UEORD2 | UEORD1 | UEORDO 
Register 0 (UEODO)| YEoTD7 | UEOTD6 | UEOTD5 | UEOTD4 | UEOTD3 | UEOTD2 | UEOTD1 | UEOTDO 


J y 


USB Endpoint 0 Data| UEORD7 | UEORD6 | UEORDS | UEORD4 | UEORDS | UEORD2 | UEORD1 | UEORDO 
Register 7 (UEOD7)) YEoTD7 | UEOTD6 | UEOTD5 | UEOTD4 | UEOTD3 | UEOTD2 | UEOTD1 | UEOTDO 


USB Endpoint 1/2 Data $0028 
Register 0 (UE1D0)| YE1TD7 | UE1TD6 | UE{TDS | UE1TD4 | UE1TD3 | UE1TD2 | UE1TD1 | UE1TDO 
USB Endpoint 1/2 Data $002F 


Register 7 (UE1D7)) YE1TD7 | UE1TD6 | UE1TD5 | UE1TD4 | UE1TD3 | UE1TD2 | UE1TD1 | UE1TDO 


= Unimplemented 
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10.5.1 USB Address Register (UADDR) 


BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
UADDR |R 
$0038 wi USBEN | UADD6 | UADD5 | UADD4 | UADD3 | UADD2 | UADD1 | UADDO 
reset: 0 0 0 0 0 0 0 0 


Figure 10-20. USB Address Register (UADDR) 


USBEN — USB Module Enable 
This read/write bit enables and disables the USB module and the USB pins. 
When USBEN is clear, the USB module will not respond to any tokens. Reset 
clears this bit. 
1 = USB function enabled. 
0= USB function disabled. 


UADD6-UADDO — USB Function Address 
These bits specify the USB address of the device. Reset clears these bits. 


10.5.2 USB Interrupt Register 0 (UIRO) 


BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
UIRO R| TXDOF RXDOF RSTF 0 0 
SUSPND | TXDOIE | RXDOIE 
$0039 W TXDOFR | RXDOFR 
reset: 0 0 0 0 0 0 0 0 
= Unimplemented 


Figure 10-21. USB Interrupt Register 0 (UIRO) 


TXDOF — Endpoint 0 Data Transmit Flag 

This read only bit is set after the data stored in Endpoint 0 transmit buffers has 
been sent and an ACK handshake packet from the host is received. Once the 
next set of data is ready in the transmit buffers, software must clear this flag by 
writing a logic 1 to the TXDOFR bit. To enable the next data packet transmis- 
sion, TXOE must also be set. If TXDOF bit is not cleared, a NAK handshake will 
be returned in the next IN transaction. 
Reset clears this bit. Writing a logic 0 to TXDOF has no effect. 

1= Transmit on Endpoint 0 has occurred. 

0= Transmit on Endpoint 0 has not occurred. 


RXDOF — Endpoint 0 Data Receive Flag 
This read only bit is set after the USB module has received a data packet and 
responded with an ACK handshake packet. Software must clear this flag by 
writing a logic 1 to the RXDOFR bit after all of the received data has been read. 
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Software must also set RXOE bit to one to enable the next data packet recep- 
tion. If RXDOF bit is not cleared, a NAK handshake will be returned in the next 
OUT transaction. 
Reset clears this bit. Writing a logic 0 to RXDOF has no effect. 

1 = Receive on Endpoint 0 has occurred. 

0= Receive on Endpoint 0 has not occurred. 


RSTF — USB Reset Flag 
This read only bit is set when a valid reset signal state is detected on the D+ 
and D- lines. This reset detection will also generate an internal reset signal to 
reset the CPU and other peripherals including the USB module. This bit is 
cleared by writing a logic 1 to the RSTFR bit in the UCR2 register. This bit is 
cleared by a POR reset. 


SUSPND — USB Suspend Flag 
To save power, this read/write bit should be set by the software if a 3ms con- 
stant idle state is detected on USB bus. Setting this bit stops the clock to the 
USB and causes the USB module to enter Suspend mode. Unnecessary ana- 
log circuitry will be powered down. Software must clear this bit after the 
Resume flag (RESUMF) is set while this Resume interrupt flag is serviced. 


TXDOIE — Endpoint 0 Transmit Interrupt Enable 
This read/write bit enables the Transmit Endpoint 0 to generate a USB interrupt 
when the TXDOF bit becomes set. 
1 = USB interrupts enabled for Transmit Endpoint 0. 
0= USB interrupts disabled for Transmit Endpoint 0. 


RXDOIE — Endpoint 0 Receive Interrupt Enable 
This read/write bit enables the Transmit Endpoint 0 to generate a USB interrupt 
when the RXDOF bit becomes set. 
1 = USB interrupts enabled for Receive Endpoint 0. 
0= USB interrupts disabled for Receive Endpoint 0. 


TXDOFR — Endpoint 0 Transmit Flag Reset 
Writing a logic 1 to this write only bit will clear the TXDOF bit if it is set.Writing a 
logic 0 to TXDOFR has no effect. Reset clears this bit. 


RXDOFR — Endpoint 0 Receive Flag Reset 
Writing a logic 1 to this write only bit will clear the RXDOF bit if it is set.Writing a 
logic 0 to RXDOFR has no effect. Reset clears this bit. 
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10.5.3 USB Interrupt Register 1 (UIR1) 


BIT 7 BIT 6 BIT5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
UIR1 R| TXD1F EOPF | RESUMF 0 0 0 
$j} XIE EOPIE +————>+—_ 
$003A W RESUMFR TXD1FR | EOPFR 
reset: 0 0 0 0 0 0 0 0 
= Unimplemented 


Figure 10-22. USB Interrupt Register 1(UIR1) 


TXD1F — Endpoint 1/Endpoint 2 Data Transmit Flag 

This read only bit is shared by Endpoint 1 and Endpoint 2. It is set after the data 
stored in the shared Endpoint 1/Endpoint 2 transmit buffer has been sent and 
an ACK handshake packet from the host is received. Once the next set of data 
is ready in the transmit buffers, software must clear this flag by writing a logic 1 
to the TXD1FR bit. To enable the next data packet transmission, TX1E must 
also be set. If TXD1F bit is not cleared, a NAK handshake will be returned in 
the next IN transaction. 
Reset clears this bit. Writing a logic 0 to TXD1F has no effect. 

1= Transmit on Endpoint 1 or Endpoint 2 has occurred. 

0= Transmit on Endpoint 1 or Endpoint 2 has not occurred. 


EOPF — End of Packet Detect Flag 
This read only bit is set when a valid End-of-Packet sequence is detected on 
the D+ and D- lines. Software must clear this flag by writing a logic 1 to the 
EOPFR bit. 
Reset clears this bit. Writing a logic 0 to EOPF has no effect. 
1= End-of-Packet sequence has been detected. 
0= End-of-Packet sequence has not been detected. 


RESUMF — Resume Flag 
This read only bit is set when USB bus activity is detected while the SUSPND 
bit is set. Software must clear this flag by writing a logic 1 to the RESUMFR bit. 
Reset clears this bit. Writing a logic 0 to RESUMF has no effect. 
1 = USB bus activity has been detected. 
0= No USB bus activity has been detected. 


RESUMFR — Resume Flag Reset 
Writing a logic 1 to this write only bit will clear the RESUMF bit if it is set. Writ- 
ing a logic 0 to RESUMFR has no effect. Reset clears this bit. 


TXD1IE — Endpoint 1/Endpoint 2 Transmit Interrupt Enable 
This read/write bit enables the USB to generate an interrupt when the shared 
Transmit Endpoint 1/Endpoint 2 interrupt flag (TXD1F) bit becomes set. Reset 
clears this bit. 
1 = USB interrupts enabled for Transmit Endpoints 1 and 2. 
0= USB interrupts disabled for Transmit Endpoints 1 and 2. 
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EOPIE — End of Packet Detect Interrupt Enable 
This read/write bit enables the USB to generate an interrupt when the EOPF bit 
becomes set. Reset clears this bit. 
1 = USB interrupts enabled for Transmit Endpoints 1 and 2. 
0= USB interrupts disabled for Transmit Endpoint 1 and 2. 


TXD1FR — Endpoint 1/Endpoint 2 Transmit Flag Reset 
Writing a logic 1 to this write only bit will clear the TXD1F bit if it is set. Writing a 
logic 0 to TXD1FR has no effect. Reset clears this bit. 


EOPFR — End of Packet Flag Reset 
Writing a logic 1 to this write only bit will clear the EOPF bit if it is set. Writing a 
logic 0 to the EOPFR has no effect. Reset clears this bit. 


10.5.4 USB Control Register 0 (UCRO) 


BIT 7 BIT6 BIT5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
ae ' TOSEQ | STALLO | TXOE RXOE | TPOSIZ3 | TPOSIZ2 | TPOSIZ1 | TPOSIZO 
reset: 0 0 0 0 0 ) 0 0 


Figure 10-23. USB Control Register 0 (UCRO) 


TOSEQ — Endpoint 0 Transmit Sequence Bit 
This read/write bit determines which type of data packet (DATAO or DATA1) will 
be sent during the next IN transaction. Toggling of this bit must be controlled by 
software. Reset clears this bit. 
1 = DATA1 Token active for next Endpoint 0 transmit. 
0= DATAO Token active for next Endpoint 0 transmit. 


STALLO — Endpoint 0 Force Stall Bit 
This read/write bit causes Endpoint 0 to return a STALL handshake when 
polled by either an IN or OUT token by the USB Host Controller. The USB hard- 
ware Clears this bit wnen a SETUP token is received. Reset clears this bit. 
1= Send STALL handshake. 
0= Default. 


TXOE — Endpoint 0 Transmit Enable 

This read/write bit enables a transmit to occur when the USB Host controller 
sends an IN token to Endpoint 0. Software should set this bit when data is 
ready to be transmitted. It must be cleared by software when no more Endpoint 
0 data needs to be transmitted. 
If this bit is 0 or the TXDOF is set, the USB will respond with a NAK handshake 
to any Endpoint 0 IN tokens. Reset clears this bit. 

1= Data is ready to be sent. 

0= Data is not ready. Respond with NAK. 
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RXOE — Endpoint 0 Receive Enable 

This read/write bit enables a receive to occur when the USB Host controller 
sends an OUT token to Endpoint 0. Software should set this bit when data is 
ready to be received. It must be cleared by software when data cannot be 
received. 
If this bit is O or the RXDOF is set, the USB will respond with a NAK handshake 
to any Endpoint 0 OUT tokens. Reset clears this bit. 

1= Data is ready to be received. 

0= Not ready for data. Respond with NAK. 


TPOSIZ3-TPOSIZO — Endpoint 0 Transmit Data Packet Size 
These read/write bits store the number of transmit data bytes for the next IN 
token request for Endpoint 0. These bits are cleared by reset. 


10.5.5 USB Control Register 1 (UCR1) 


BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
oo. - TI1SEQ |ENDADD) TX1E |FRESUM) TP1SZ3 | TP1S1IZ2 ) TP1SIZ1 | TP1SIZ0 
reset: 0 0 0 0 0 0 0 0 


Figure 10-24. USB Control Register 1 (UCR1) 


T1SEQ — Endpoint1/Endpoint 2 Transmit Sequence Bit 
This read/write bit determines which type of data packet (DATAO or DATA1) will 
be sent during the next IN transaction directed to Endpoint 1 or Endpoint 2. 
Toggling of this bit must be controlled by software. Reset clears this bit. 
1 = DATA1 Token active for next Endpoint 1/Endpoint 2 transmit. 
0= _ DATAO Token active for next Endpoint 1/Endpoint 2 transmit. 


ENDADD — Endpoint Address Select 
This read/write bit specifies whether the data inside the registers 
UE1D0-UE1D7 are used for Endpoint 1 or Endpoint 2. If all the conditions for a 
successful Endpoint 2 USB response to a hosts IN token are satisfied 
(TXD1F=0, TX1E=1, STALL2=0, and ENABLE2=1) except that the ENDADD bit 
is configured for Endpoint 1, the USB responds with a NAK handshake packet. 
1= The data buffers are used for Endpoint 2. 
0= The data buffers are used for Endpoint 1. 
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TX1E — Endpoint 1/Endpoint 2 Transmit Enable 

This read/write bit enables a transmit to occur when the USB Host controller 
sends an IN token to Endpoint 1 or Endpoint 2. The appropriate endpoint 
enable bit, ENABLE1 or ENABLE2 bit in the UCR2 register, should also be set. 
Software should set the TX1E bit when data is ready to be transmitted. It must 
be cleared by software when no more data needs to be transmitted. 
If this bit is O or the TXD1F is set, the USB will respond with a NAK handshake 
to any Endpoint 1 or Endpoint 2 directed IN tokens. Reset clears this bit. 

1= Data is ready to be sent. 

0= Data is not ready. Respond with NAK. 


FRESUM — Force Resume 
This read/write bit forces a resume state (“K” or non-idle state) onto the USB 
data lines to initiate a remote wake-up. Software should control the timing of the 
forced resume to be between 10ms and 15 ms. Setting this bit will not cause 
the RESUMF bit to set. 
1 = Force data lines to “K” state. 
O= Default. 


TP1SIZ3-TP1SIZO — Endpoint 1/Endpoint 2 Transmit Data Packet Size 
These read/write bits store the number of transmit data bytes for the next IN 
token request for Endpoint 1 or Endpoint 2. These bits are cleared by reset. 


10.5.6 USB Control Register 2 (UCR2) 


BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT O 
R2 R 0 TX1ST 0 
ue ENABLE2|ENABLE1| STALL2 | STALL1 
$0037 WwW TX1STR 
reset: - - 0 - 0 0 0 0 
= Unimplemented 


Figure 10-25. USB Control Register 2 (UCR2) 


TX1STR — Clear Transmit First Flag 
Writing a logic 1 to this write-only bit will clear the TX1ST bit if it is set. Writing a 
logic 0 to the TX1STR has no effect. Reset clears this bit. 


TX1ST — Transmit First Flag 

This read-only bit is set if the Endpoint 0 Data Transmit Flag (TXDOF) is set 
when the USB control logic is setting the Endpoint 0 Data Receive Flag 
(RXDOF). That is, this bit will be set if an Endpoint 0 Transmit Flag is still set at 
the end of an Endpoint 0 reception. This bit lets the firmware know that the 
Endpoint 0 transmission happened before the Endpoint 0 reception. Reset 
clears this bit. 

1= IN transaction occurred before SETUP/OUT. 

0 = _ IN transaction occurred after SETUP/OUT. 
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ENABLE2 — Endpoint 2 Enable 
This read/write bit enables Endpoint 2 and allows the USB to respond to IN 
packets addressed to Endpoint 2. Reset clears this bit. 
1 = Endpoint 2 is enabled and can respond to an IN token. 
0= Endpoint 2 is disabled. 


ENABLE1 — Endpoint 1 Enable 
This read/write bit enables Endpoint 1 and allows the USB to respond to IN 
packets addressed to Endpoint 1. Reset clears this bit. 
1 = Endpoint 1 is enabled and can respond to an IN token. 
0= Endpoint 1 is disabled. 


STALL2 — Endpoint 2 Force Stall Bit 
This read/write bit causes Endpoint 2 to return a STALL handshake when 
polled by either an IN or OUT token by the USB Host Controller. Reset clears 


this bit. 
1= Send STALL handshake. 
0= Default. 


STALL1 — Endpoint 1 Force Stall Bit 
This read/write bit causes Endpoint 1 to return a STALL handshake when 
polled by either an IN or OUT token by the USB Host Controller. Reset clears 


this bit. 
1= Send STALL handshake. 
0= Default. 


10.5.7 USB Status Register (USR) 


BIT 7 BIT 6 BIT5 BIT 4 BIT 3 BIT 2 BIT 1 BIT O 
USR R}| RSE SETUP 0 0 
ce RPSIZ3 | RPSIZ2 | RPSIZ1 | RPSIZO 
$003D WwW 
reset: U U U U U U U U 
= Unimplemented 


Figure 10-26. USB Status Register (USR) 


RSEQ — Endpoint 0 Receive Sequence Bit 
This read only bit indicates the type of data packet last received for Endpoint 0 
(DATAO or DATA1). 
1 = DATA1 Token received in last Endpoint 0 receive. 
0= DATAO Token received in last Endpoint 0 receive. 


SETUP — SETUP Token Detect Bit 
This read only bit indicates that a valid SETUP token has been received. 
1= Last token received for Endpoint 0 was a SETUP token. 
0= Last token received for Endpoint 0 was not a SETUP token. 
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RPSIZ3-RPSIZO — Endpoint 0 Receive Data Packet Size 
These read only bits store the number of data bytes received for the last OUT 
or SETUP transaction for Endpoint 0. These bits are not affected by reset. 


10.5.8 USB Endpoint 0 Data Registers (UEOQDO-UE0D7) 


BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
UEODO R| UEORD7 | UEORD6 | UEORDS5 | UEORD4 | UEORDS | UEORD2 | UEORD1 | UEORDO 
$0020 W| UEOTD7 | UEOTD6 | UEOTDS5 | UEOTD4 | UEOTDS | UEOTD2 | UEOTD1 | UEOTDO 


UEOD7 R|} UEORD7 | UEORD6 | UEORD5 | UEORD4 | UEORD3 | UEORD2 | UEORD1 | UEORDO 
$0027 W| UEOTD7 | UEOTD6 | UEOTD5 | UEOTD4 | UEOTD3 | UEOTD2 | UEOTD1 | UEOTDO 
reset: x x x x x X X X 


Figure 10-27. USB Endpoint 0 Data Register (UEODO-UE0D7) 


UEORD7 - UEORDO — Endpoint 0 Receive Data Buffer 
These read only bits are serially loaded with OUT token or SETUP token data 
received over the USB’s D+ and D-— pins. 


UEOTD7 - UEOTDO — Endpoint 0 Transmit Data Buffer 
These write only buffers are loaded by software with data to be sent on the 
USB bus on the next IN token directed at Endpoint 0. 


10.5.9 USB Endpoint 1/Endpoint 2 Data Registers (UE1D0-UE1D7) 


BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 


c 
iT 
S 
oO 
D 


$0028 W| UE1TD7 | UE1TD6 | UE1TD5 | UE1TD4 | UE1TDS | UE1TD2 | UE1TD1 | UE1TDO 


UE1D7 R 
$002F W| UE1TD7 | UE1TD6 | UE1TD5 | UE1TD4 | UE1TD3 | UE1TD2 | UE1TD1 | UE1TDO 
reset: x x x x x X X X 


Figure 10-28. USB Endpoint 1/Endpoint2 Data Registers (UE1D0-UE1D7) 


UE1TD7 - UE1TDO — Endpoint 1/ Endpoint 2 Transmit Data Buffer 
These write only buffers are loaded by software with data to be sent on the 
USB bus on the next IN token directed at Endpoint 1 or Endpoint 2. These buff- 
ers are shared by Endpoints 1 and 2 and depend on proper configuration of the 
ENDADD bit. 


10.6 USB INTERRUPTS 


The USB module is capable of generating interrupts and causing the CPU to 
execute the USB interrupt service routine. There are three types of USB 
interrupts: 
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¢ End of Transaction interrupts signify a completed transaction (receive or 
transmit) 


¢ Resume interrupts signify that the USB bus is reactivated after having 
been suspended 


¢ End of Packet interrupts signify that a low speed end of packet signal 
was detected 


All USB interrupts share the same interrupt vector. Firmware is responsible for 
determining which interrupt is active. 


10.6.1 USB End of Transaction Interrupt 


There are three possible end of transaction interrupts: Endpoint 0 Receive, 
Endpoint 0 Transmit, and a shared Endpoint 1 or Endpoint 2 Transmit. End of 
transaction interrupts occur as detailed in the following sections. 


10.6.1.1 Receive Control Endpoint 0 


For a Control OUT transaction directed at Endpoint 0, the USB module will 
generate an interrupt by setting the RXDOF flag in the UIRO register. The 
conditions necessary for the interrupt to occur are shown in the flowchart of 
Figure 10-29. 


SETUP transactions cannot be stalled by the USB function. A SETUP received by 
a control endpoint will clear the STALLO bit if it is set. The conditions for receiving 
a SETUP interrupt are shown in Figure 10-30. 


10.6.1.2 Transmit Control Endpoint 0 


For a Control IN transaction directed at Endpoint 0, the USB module will generate 
an interrupt by setting the TXDOF flag in the UIRO register. The conditions 
necessary for the interrupt to occur are shown in the flowchart of Figure 10-31. 


10.6.1.3 Transmit Endpoint 1 and Transmit Endpoint 2 


Transmit Endpoints 1 and 2 share their interrupt flag. For an IN transaction 
directed at Endpoint 1 or 2, the USB module will generate an interrupt by setting 
the TXD1F flag in the UIR1 register. The conditions necessary for the interrupt to 
occur are shown in the flowchart of Figure 10-32. 


10.6.2 Resume Interrupt 


The USB module will generate a USB interrupt if low speed bus activity is 
detected after entering the suspend state. A transition of the USB data lines to the 
non-idle state (“K” state) while in the suspend mode will set the RESUMF flag in 
the UIR1 register. There is no interrupt enable bit for this interrupt source and an 
interrupt will be executed if the | bit in the CCR is cleared. A resume interrupt can 
only occur while the MC68HCO5JB3 is in the suspend mode. 
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10.6.3 End of Packet Interrupt 


The USB module can generate a USB interrupt upon detection of an end of 
packet signal (a single ended 0) for low speed devices. Upon detection of an SEO 
sequence, the USB module sets the EOPF bit and will generate an interrupt if the 
EOPIE bit in the UIR1 register is set. 
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Valid OUT token 
received for Endpoint 0 


l Y 
C Valid DATA token > N Time-out 


received for Endpoint 0? if. ai cn ibe 
| v 


Endpoint 0 Receive Enabled? “x y 
(USBEN = 1) 


yy 


Endpoint 0 Receive Not Stalled? N Send STALL 


x 

(STALLO = 0) +) *| Handshake | 
“y 
e 


No Response 
from USB function 


LY 


Endpoint 0 Receive Ready to Receive? 
(RXOE = 1) && (RXDOF = 0) 


Y 
Accept Data 
Set/clear RSEQ bit 


N Send NAK 
Handshake 


' 


s N Ignore transaction 
< Error free DATA packet? y =| — No response from | 
| Y USB function 


Set RXDOF to 1 


Receive Control Endpoint “\ N 
Interrupt Enabled? 
(RXDOIE = 1) wy 
1 Y 
Valid transaction 
Interrupt generated No Interrupt 


Figure 10-29. OUT Token Data Flow for Receive Endpoint 0 
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Valid SETUP token 
received for Endpoint 0 
F 


C Endpoint 0 Receive Enabled? N No Response 


(USBEN = 1) from USB function 


\y 


Endpoint 0 Receive Ready to Receive? N No Response 
(RXOE = 1) && (RXDOF = 0) from USB function 


STALLO = 0? Clear STALLO bit 


Accept Data 
set/clear RSEQ bit es 
Set SETUP to 1 


i 
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Set RXDOF to 1 
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Interrupt Enabled? | 
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|y 
No Interrupt 
Valid transaction 
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Figure 10-30. SETUP Token Data Flow for Receive Endpoint 0 
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Valid IN token 
received for Endpoint 0 


Y 
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| Y 
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(STALLO = 0) Handshake 
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Handshake 


Transmit Endpoint ready to Transfer? 
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No Response 
from USB function 


ACK received and no 
Time-out condition occur? 


| Y 
| Set TXDOF to 1 


! 


Transmit Endpoint “SS N 
Interrupt Enabled? 
(TXDOIE = 1) 


No Interrupt 


Valid transaction 
Interrupt generated 


Figure 10-31. IN Token Data Flow for Transmit Endpoint 0 
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Valid IN token 
received for Endpoints 1 or 2 
Transmit Endpoint Enabled? N No Response 
(USBEN = 1) from USB function 


VY 


q Transmit Endpoint not Stalled by firmware? +) N Send STALL 


(STALL1 & ENDP1) + (STALL2 & ENDP2) Handshake 


yY 


Transmit Endpoint ready to Transfer? 
(TX1E = 1) && (TXD1IF = 0) & 
((ENDP2 & ENDADD) + (ENDP1 & ENDADD)) 


Send NAK 
Handshake 


Send DATA 
Data PID set by T1SEQ 


ACK received and no N No Response 
Time-out condition occurs? from USB function 


Y 


Set TXD1F to 1 


Y 


Transmit Endpoint 


Interrupt Enabled? y 
(TXD1IE = 1) No Interrupt 

Valid transaction Note: 

Interrupt generated ENDP1 is Endpoint 1 directed traffic 


ENDP2 is Endpoint 2 directed traffic 


Figure 10-32. IN Token Data Flow for Transmit Endpoint 1/2 


MOTOROLA UNIVERSAL SERIAL BUS MODULE MC68HC05JB3 
10-32 REV 1 


For More Information On This Product, 
Go to: www.freescale.com 


Freescale Semiconductor, Inc. 
November 5, 1998 | GENERAL RELEASE SPECIFICATION 


SECTION 11 
OPTICAL INTERFACE 


The MC68HC05JB3 MCU has four pairs of Optical Interfaces, configured through 
Port-A. This port has built-in optical coupler interface devices, which can be 
directly connected to IR displacement encoders, such as in optical mouse and 
optical joystick applications. 


OVERVIEW 


In practical designs, each axis requires two optical couplers to detect the displace- 
ment. Hence, the eight optical interfaces on port-A are enabled in pairs, with each 
pair enabled by a bit in the Optical Interface Enable Register (S0E). Figure 11-1 
shows a one pair of the optical interface. Table 11-1 shows the port-A configura- 
tion for the four pairs. 


Table 11-1. Port-A Optical Interface Pairs 


Optical Coupler Port pin used Enable bit in OIER 


Pair 1 PAO and PA1 OIEO 


Pair 2 PA2 and PAS OIE1 


Pair 3 PA4 and PAS OIE2 


Pair 4 PA6 and PA7 OIE3 


For optimal performance, the reference voltage used in the optical interface 
module is selectable from eight predefined values, as shown in Figure 11-2. and 
Table 11-2. This allows the optical interface to be easily configured by software to 
match the IR displacement encoders. The reference voltage is selected using the 
bits VREFO-VREF2 in the OIER. 
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Output 
Buffer 


PAX 
Port Logic 


PAx MUX 
Optical 
Interface 
select 
OPTI_EN = 
VREF s 
OIEn 2 
lect S 
Optical e 
Interface 
PA(x+1) 
MUX 
al : Port Logic 
Output 
Buffer 
Figure 11-1. A pair of Optical Coupler Interface 
VREF2 
VREF1 VREF 
VREFO Voltage Selector 
-— >} enable 
OIE2 
CIES enable 
Ole Voltage Divider 
OIEO 
OPTI_EN 
To MUX 
PAX 
Dynamic 
Input 
Impedance 
OPTICAL 
INTERFACE = 
Figure 11-2. Optical Interface Comparator 
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11.2 OPTICAL INTERFACE ENABLE REGISTER 


The OIER register controls the operation of the optical interface devices on 
Port-A. This register is located at address $0E. 


BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
OIER R 
TCMPE VREF2 VREF1 VREFO OIE3 OIE2 OIE1 OIEO 
$000E WwW 
reset: 0 0 0 0 0 0 0 0 


Figure 11-3. Optical Interface Enable Register (TCSR) 


OIEO — Optical Interface pair 0 Enable 
1 = PAO and PA1 optical interface are enabled. 
0= PAO and PA1 optical interface are disabled. 


OIE1 — Optical Interface pair 1 Enable 
1 = PA2 and PA optical interface are enabled. 
0= PA2 and PAS optical interface are disabled. 


OIE2 — Optical Interface pair 2 Enable 
1 = PA4 and PAS optical interface are enabled. 
0= PA4 and PAS optical interface are disabled. 


OIE3 — Optical Interface pair 3 Enable 
1 = PA6 and PA7 optical interface are enabled. 
0= PA6 and PA7 optical interface are disabled. 


VREF[0:2] — Reference Voltage Selection 
These 3 bits are used to select the optical interface reference voltage. 


Table 11-2. Optical Interface Reference Voltage Selection 


VREF2 VREF1 VREFO Reference Voltage (mV), Vpp=5V 


0 0 0 300 


430 
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TCMPE — Timer Input Capture Comparator Enable 
This bit is used to enable the comparator in the 16-bit timer input capture 
circuit. Please refer to 16-BIT TIMER section. 
1= Timer input capture comparator is selected. 
0= Timer input capture comparator schmitt trigger is selected. 
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SECTION 12 
INSTRUCTION SET 


This section describes the addressing modes and instruction types. 


12.11 ADDRESSING MODES 


The CPU uses eight addressing modes for flexibility in accessing data. The 
addressing modes define the manner in which the CPU finds the data required to 
execute an instruction. The eight addressing modes are the following: 


Inherent 

Immediate 

Direct 

Extended 

Indexed, No Offset 
Indexed, 8-Bit Offset 
Indexed, 16-Bit Offset 
Relative 


12.1.1 Inherent 


Inherent instructions are those that have no operand, such as return from interrupt 
(RTI) and stop (STOP). Some of the inherent instructions act on data in the CPU 
registers, such as set carry flag (SEC) and increment accumulator (INCA). 
Inherent instructions require no memory address and are one byte long. 


12.1.2 Immediate 


Immediate instructions are those that contain a value to be used in an operation 
with the value in the accumulator or index register. Immediate instructions require 
no memory address and are two bytes long. The opcode is the first byte, and the 
immediate data value is the second byte. 
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12.1.3 Direct 


Direct instructions can access any of the first 256 memory addresses with two 
bytes. The first byte is the opcode, and the second is the low byte of the operand 
address. In direct addressing, the CPU automatically uses $00 as the high byte of 
the operand address. BRSET and BRCLR are three-byte instructions that use 
direct addressing to access the operand and relative addressing to specify a 
branch destination. 


12.1.4 Extended 


Extended instructions use only three bytes to access any address in memory. The 
first byte is the opcode; the second and third bytes are the high and low bytes of 
the operand address. 


When using the Motorola assembler, the programmer does not need to specify 
whether an instruction is direct or extended. The assembler automatically selects 
the shortest form of the instruction. 


12.1.5 Indexed, No Offset 


Indexed instructions with no offset are one-byte instructions that can access data 
with variable addresses within the first 256 memory locations. The index register 
contains the low byte of the conditional address of the operand. The CPU 
automatically uses $00 as the high byte, so these instructions can address 
locations $0000—$00FF. 


Indexed, no offset instructions are often used to move a pointer through a table or 
to hold the address of a frequently used RAM or I/O location. 


12.1.6 Indexed, 8-Bit Offset 


Indexed, 8-bit offset instructions are two-byte instructions that can access data 
with variable addresses within the first 511 memory locations. The CPU adds the 
unsigned byte in the index register to the unsigned byte following the opcode. The 
sum is the conditional address of the operand. These instructions can access 
locations $0000—$01 FE. 


Indexed 8-bit offset instructions are useful for selecting the kth element in an 
n-element table. The table can begin anywhere within the first 256 memory 
locations and could extend as far as location 510 ($01FE). The k value is typically 
in the index register, and the address of the beginning of the table is in the byte 
following the opcode. 


MOTOROLA INSTRUCTION SET MC68HC05JB3 
12-2 REV 1 


For More Information On This Product, 
Go to: www.freescale.com 


Freescale Semiconductor, Inc. 
November 5, 1998 | GENERAL RELEASE SPECIFICATION 


12.1.7 Indexed, 16-Bit Offset 


Indexed, 16-bit offset instructions are three-byte instructions that can access data 
with variable addresses at any location in memory. The CPU adds the unsigned 
byte in the index register to the two unsigned bytes following the opcode. The sum 
is the conditional address of the operand. The first byte after the opcode is the 
high byte of the 16-bit offset; the second byte is the low byte of the offset. These 
instructions can address any location in memory. 


Indexed, 16-bit offset instructions are useful for selecting the kth element in an 
n-element table anywhere in memory. 


As with direct and extended addressing, the Motorola assembler determines the 
shortest form of indexed addressing. 


12.1.8 Relative 


Relative addressing is only for branch instructions. If the branch condition is true, 
the CPU finds the conditional branch destination by adding the signed byte 
following the opcode to the contents of the program counter. If the branch 
condition is not true, the CPU goes to the next instruction. The offset is a signed, 
two’s complement byte that gives a branching range of —128 to +127 bytes from 
the address of the next location after the branch instruction. 


When using the Motorola assembler, the programmer does not need to calculate 
the offset, because the assembler determines the proper offset and verifies that it 
is within the span of the branch. 


12.1.9 Instruction Types 


The MCU instructions fall into the following five categories: 
¢ Register/Memory Instructions 
* Read-Modify-Write Instructions 
¢ Jump/Branch Instructions 
¢ Bit Manipulation Instructions 
* Control Instructions 
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12.1.10 Register/Memory Instructions 


Most of these instructions use two operands. One operand is in either the 
accumulator or the index register. The CPU finds the other operand in memory. 
Table 12-1 lists the register/memory instructions. 


MOTOROLA 
12-4 


Table 12-1. Register/Memory Instructions 


Instruction Mnemonic 
Add Memory Byte and Carry Bit to Accumulator ADC 
Add Memory Byte to Accumulator ADD 
AND Memory Byte with Accumulator AND 
Bit Test Accumulator BIT 
Compare Accumulator CMP 
Compare Index Register with Memory Byte CPX 
EXCLUSIVE OR Accumulator with Memory Byte EOR 
Load Accumulator with Memory Byte LDA 
Load Index Register with Memory Byte LDX 
Multiply MUL 
OR Accumulator with Memory Byte ORA 
Subtract Memory Byte and Carry Bit from Accumulator SBC 
Store Accumulator in Memory STA 
Store Index Register in Memory STX 
Subtract Memory Byte from Accumulator SUB 
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12.1.11 Read-Modify-Write Instructions 


These instructions read a memory location or a register, modify its contents, and 
write the modified value back to the memory location or to the register. The test for 
negative or zero instruction (TST) is an exception to the read-modify-write 
sequence because it does not write a replacement value. Table 12-2 lists the 
read-modify-write instructions. 


Table 12-2. Read-Modify-Write Instructions 


Instruction Mnemonic 

Arithmetic Shift Left ASL 

Arithmetic Shift Right ASR 
Clear Bit in Memory BCLR 
Set Bit in Memory BSET 
Clear CLR 
Complement (One’s Complement) COM 
Decrement DEC 
Increment INC 

Logical Shift Left LSL 

Logical Shift Right LSR 

Negate (Two’s Complement) NEG 
Rotate Left through Carry Bit ROL 
Rotate Right through Carry Bit ROR 
Test for Negative or Zero TST 


12.1.12 Jump/Branch Instructions 


Jump instructions allow the CPU to interrupt the normal sequence of the program 
counter. The unconditional jump instruction (JMP) and the jump to subroutine 
instruction (JSR) have no register operand. Branch instructions allow the CPU to 
interrupt the normal sequence of the program counter when a test condition is 
met. If the test condition is not met, the branch is not performed. All branch 
instructions use relative addressing. 


Bit test and branch instructions cause a branch based on the state of any 
readable bit in the first 256 memory locations. These three-byte instructions use a 
combination of direct addressing and relative addressing. The direct address of 
the byte to be tested is in the byte following the opcode. The third byte is the 
signed offset byte. The CPU finds the conditional branch destination by adding the 
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third byte to the program counter if the specified bit tests true. The bit to be tested 
and its condition (set or clear) is part of the opcode. The span of branching is from 
—128 to +127 from the address of the next location after the branch instruction. 
The CPU also transfers the tested bit to the carry/borrow bit of the condition code 
register. Table 12-3 lists the jump and branch instructions. 


Table 12-3. Jump and Branch Instructions 


Instruction Mnemonic 
Branch if Carry Bit Clear BCC 
Branch if Carry Bit Set BCS 
Branch if Equal BEQ 
Branch if Half-Carry Bit Clear BHCC 
Branch if Half-Carry Bit Set BHCS 
Branch if Higher BHI 
Branch if Higher or Same BHS 
Branch if IRQ Pin High BIH 
Branch if IRQ Pin Low BIL 
Branch if Lower BLO 
Branch if Lower or Same BLS 
Branch if Interrupt Mask Clear BMC 
Branch if Minus BMI 
Branch if Interrupt Mask Set BMS 
Branch if Not Equal BNE 
Branch if Plus BPL 
Branch Always BRA 
Branch if Bit Clear BRCLR 
Branch Never BRN 
Branch if Bit Set BRSET 
Branch to Subroutine BSR 
Unconditional Jump JMP 
Jump to Subroutine JSR 
MOTOROLA INSTRUCTION SET MC68HCO5UJB3 
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12.1.13 Bit Manipulation Instructions 


The CPU can set or clear any writable bit in the first 256 bytes of memory. Port 
registers, port data direction registers, timer registers, and on-chip RAM locations 
are in the first 256 bytes of memory. The CPU can also test and branch based on 
the state of any bit in any of the first 256 memory locations. Bit manipulation 


instructions use direct addressing. Table 12-4 lists these instructions. 


Table 12-4. Bit Manipulation Instructions 


Instruction Mnemonic 
Clear Bit BCLR 
Branch if Bit Clear BRCLR 
Branch if Bit Set BRSET 
Set Bit BSET 


12.1.14 Control Instructions 


These register reference instructions control CPU operation during program 
execution. Control instructions, listed in Table 12-5, use inherent addressing. 


MC68HC05JB3 
REV 1 


Table 12-5. Control Instructions 


Instruction Mnemonic 
Clear Carry Bit CLC 
Clear Interrupt Mask CLI 
No Operation NOP 
Reset Stack Pointer RSP 
Return from Interrupt RTI 
Return from Subroutine RTS 
Set Carry Bit SEC 
Set Interrupt Mask SEI 
Stop Oscillator and Enable IRQ Pin STOP 
Software Interrupt SWI 
Transfer Accumulator to Index Register TAX 
Transfer Index Register to Accumulator TXA 
Stop CPU Clock and Enable Interrupts WAIT 
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12.1.15 Instruction Set Summary 


Table 12-6 is an alphabetical list of all M68HCO5 instructions and shows the effect 


of each instruction on the condition code register. 


Table 12-6. Instruction Set Summary 


" Effecton | 8, /2| 2 % 
Se Operation Description CCR es isi sis 
Form Ss (a/ 3|> 

I |IN/Z <x {e) Oo Oo 

ADC #opr IMM |AQ} ii 2 

ADC opr DIR |B9| dd | 3 

ADC opr : EXT |C9/hhIl] 4 

ADG opr.X Add with Carry A «€ (A) + (M) + (C) —lt}t 1x2 |pDoleet! 5 

ADC opr,X IX1 |E9| ff 4 

ADC ,X IX FQ 3 

ADD #opr IMM |AB]_ ii 2 

ADD opr DIR |BB| dd | 3 

ADD opr : EXT |CB/hhil| 4 

ADD opr.X Add without Carry A<€ (A) + (M) —|t)t x2 |DBleeff! 5 

ADD opr,X IX1 |EB] ff 4 

ADD ,X IX FB 3 

AND #opr IMM |A4]_ ii 2 

AND opr DIR |B4|/ dd | 3 

AND opr ‘ EXT |C4/hhil] 4 

AND opr,X pegiga- an BAM) he IX2 |D4leeff] 5 

AND opr,X IX1 |E4| ff 4 

AND ,X IX F4 3 

ASL opr 38] dd 5 

eile Arithmetic Shift Left 2 = : 

ASLX (Same as LSL) CH <—0 Slick EF t 58 3 

ASL opr,X b7 b0 68 | ff 6 

ASL ,X 78 5 

ASR opr DIR |37) dd | 5 

ASRA > INH | 47 3 

ASRX Arithmetic Shift Right Ba ae (e —|t}4 INH | 57 3 

ASR opr,X ey Pu IX1 |67| ff | 6 

ASR ,X IX 77 5 

BCC rel aaa Ue PC < (PC) +2+rel?C=0 ie lel REL oa -Hp, 8 

DIR (b0)} 11) dd | 5 

DIR (b1)} 13] dd | 5 

DIR (b2)} 15] dd | 5 

: __|__|__|__]DIR (63); 17] dd) 5 

BCLR n opr Clear Bit n Mn <0 DIR (b4)| 19] dd 5 
DIR (b5);}1B] dd | 5 

DIR (b6);}1D] dd | 5 

DIR (b7);}1F | dd | 5 

Branch if Carry Bit nip: |e 

BCS rel Set (Same as BLO) PC < (PC) +2+ rel? C=1 REL |25] rr 3 

BEQ re/ Branch if Equal PC < (PC) +2+rel?Z=1 —|—|— REL |27] rr 3 

MOTOROLA INSTRUCTION SET MC68HC05JB3 

12-8 REV 1 


For More Information On This Product, 
Go to: www.freescale.com 


Freescale Semiconductor, Inc. 
GENERAL RELEASE SPECIFICATION 


November 5, 1998 


Table 12-6. Instruction Set Summary (Continued) 


Z Effecton | 8, /2| 2 % 
sue Operation Description CCR SBisiElts 
Form 3 s |o/ 2 | > 

H|I|N|z/c] = |6| & | O 
BHCC rel Brann HalGany |  pesa(Pc)+2ereea=o0" (=| I=) iReL. fae) me |':8 
Bit Clear 
BHCS rel Brann HalCaMys| pez <(Pey 42 iereead: |e al Sheet. poll.) 3 
Bit Set 
BHI rel Branch if Higher PC < (PC) +2+ rel? CvZ=0 |—|—/—|—|—|} REL | 22] rr 3 
BHS rel Slanauh MOper cr) “p@eipe) eo rales! : ||} | VEL |)24 |yaie 33 
Same 
BIH rel hg Hein PC < (PC) +2+rel?IRQ=1 |—|—/—/—/—] REL |2F| rr | 3 
BIL rel ions PD PC < (PC) +2+ref?IRQ=0 |—|—/—/—|/—| REL |2E| rr | 3 
BIT #opr IMM |A5} ii 2 
BIT opr : DIR |B5| dd] 3 
BIT opr Roe eas i _[|_}.}.[_} ext Jes}nni) 4 
BIT opr,X an ee e IX2 |D5/eeff] 5 
BIT opr,X yey IX1 |E5) ff | 4 
BIT ,X IX |F5| p | 3 
BLO rel oo PC<(PC)+24rel?C=1 |—|—|-|-|—] REL [25] rr | 3 
(Same as BCS) aan 
BLS rel ELAPOITONCTON “| RE (PG\ aoa el Oye (Po a Ret. 23) 8 
Same 
Branch if Interrupt 
BMC rel PC <—(PC)+2+rel?1=0 |—|—/—|—/—| REL |2c] mr | 3 
Mask Clear 
BMI rel Branch if Minus PC < (PC) +2+rel?N=1 —|—|—|/—|—| REL |2B] rr 3 
BMS rel eae eae: PC (PC)+2+ref?1=1 |—|—|—/—|-] REL |2D] mr | 3 
Mask Set 
BNE rel Branch if Not Equal PC <(PC)+2+rel?Z=0 |—/—|—/—|—| REL | 26) rr 3 
BPL rel Branch if Plus PC <(PC)+2+rel?N=0 |—j—/—|—/—] REL |2A] rr 3 
BRA rel Branch Always PC < (PC) +2+4+re/?1=1 —|—|—|/—|—| REL |20] rr 3 
DIR (b0)| 01 |ddrr| 5 
DIR (b1)|03|ddrr} 5 
DIR (b2)| 05 |ddrr} 5 
us DIR (b3)| 07 |ddrr} 5 
? = poe pee Pe Pee 
BRCLR n opr re/|Branch if bit n clear PC « (PC) +2+ rel? Mn=0 t DIR (b4)) 09 dd rr} 5 
DIR (b5)|OB|dd rr} 5 
DIR (b6)|OD|dd rr} 5 
DIR (b7)|OF |dd rr} 5 
DIR (b0)|00|/ddrr| 5 
DIR (b1)|02|ddrr} 5 
DIR (b2)| 04 |ddrr} 5 
ant DIR (b3)}06|ddrr| 5 
? = pee pee, a ae 
BRSET n opr rel|Branch if Bit n Set PC < (PC) + 2+ rel? Mn=1 t DIR (b4)) 08 |dd rr} 5 
DIR (b5)|OA|dd rr} 5 
DIR (b6)|0C|dd rr} 5 
DIR (b7)|OE|dd rr} 5 
BRN rel Branch Never PC < (PC) +2+ rel? 1=0 —|—|—|—|—| REL |21] rr 3 
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Table 12-6. Instruction Set Summary (Continued) 


Z Effecton | 8, /2| 2 % 
lies Operation Description CCR Ss isisis 
Form Ss |o/8/| > 

I iIN;Z/C <q O10 Oo 
DIR (bo)! 10] da | 5 
DIR (b1)/12| dd | 5 
DIR (b2)/14| dd | 5 
||| [DIR (3)} 16) dd | 5 
BSET n opr Set Bit n Mn<1 DIR (b4)|18| dd 5 
DIR (b5)/1A| dd | 5 
DIR (b6)/1C| dd | 5 
DIR (b7)/1E| dd | 5 
PC < (PC) + 2; push (PCL) 
Branch to SP < (SP) — 1; push (PCH) ne 
pone Subroutine SP < (SP) - 1 BE eS a 6 
PC < (PC) + rel 

CLC Clear Carry Bit C<0 —|—|—|]0]| INH |98 2 

CLI Clear Interrupt Mask 1-0 0|—|—/—| INH |9A 2 

CLR opr M < $00 DIR |3F| dd 5 

CLRA A < $00 INH | 4F 3 

CLRX Clear Byte X + $00 —!0}1/—| INH |5F 3 

CLR opr,X M < $00 IX1 |6F| ff | 6 

CLR ,X M < $00 IX |7F 5 

CMP #opr IMM |A1]. ii 2 

CMP opr Goins DIR |Bi| dd | 3 

CMP opr EXT /Ci}hhil| 4 

CMP opr,X ee > AM) IF} ]) 1x2 |ptleetf} 5 

CMP opr,X yey tic HEHE) 24 

CMP ,X IX |FI 4 

COM opr M < (M) = $FF —(M) DIR 133] dd | 5 

COMA aarasen weenie A < (A) = $FF-(M) INH | 43 3 

COMX (one's oi een X < (X) = $FF — (M) —l:/2]1] INH |53 3 

COM opr,X P M < (M) = $FF —(M) IX1 |63] ff | 6 

COM ,X M < (M) = $FF —(M) IX |73 5 

CPX #opr IMM |A3]_ ii 2 

CPX opr pie cee DIR |B3) dd | 3 

CPX opr EXT /C3}hhil| 4 

CPX opr.X ae aay) I} }"] 1x2 |p3leetf} 5 

CPX opr,X yey IX1 |E3) ft | 4 

CPX ,X IX |F3 3 

DEC opr M< (M)—1 DIR |3A| dd | 5 

DECA Ac (A)-1 INH |4A 3 

DECX Decrement Byte X — (X)-1 —|t}t]/—]| INH |5A 3 

DEC opr,X M<(M)-1 IX1 |6A| ff | 6 

DEC ,X M< (M)—-1 IX |7A 5 

EOR #opr IMM |A8}/_ ii 2 

EOR opr eteOR DIR |B8| dd | 3 

BOR 0pr Accumulator with A < (A) @ (M) cl elif Cert “CS DN =e 

EOR opr,X coke aye IX2 |D8leeff] 5 

EOR opr,X yey IX1 |eEs8| ff | 4 

EOR ,X IX |F8 3 
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Table 12-6. Instruction Set Summary (Continued) 


Effect on ” o| oc 
Source 0 — CCR 2 }3/ 5/3 
peration Description sO /|o|/35/] 29 
Form ss |a/3/ > 
H/I|N/Z\C| 0190 /|°P 
INC opr M < (M) +1 DIR /3C| dd] 5 
INCA A«€ (A) +1 INH |4C 3 
INCX Increment Byte X & (X) +1 —/—|t}t/—| INH |5C 3 
INC opr,xX M< (M) +1 IX1 6C| ff 6 
INC ,X M < (M) +1 IX |7C 5 
JMP opr DIR |BC] dd 2 
JMP opr EXT |CC/hhil}| 3 
JMP opr,X Unconditional Jump PC < Jump Address —|—|—|—|—| IX2 |DCl/eeff|] 4 
JMP opr,xX IX1 EC] ff 3 
JMP ,X IX FC 2 
pen Ope PC < (PC) +n(n=1, 2, or 3) BIBS (| Ge "62 
JSR opr ; EXT |CD/hhil}| 6 
Push (PCL); SP < (SP) - 1 
JSR opr,X Jump to Subroutine p : —|—|—|—|—| IX2 |DD/eeff| 7 
ush (PCH); SP < (SP) - 1 
coin OPE PC < Conditional Address ves eee ke 
JSR ,X IX FD 5 
LDA #opr IMM |A6} ii 2 
LDA opr DIR |B6| dd | 3 
LDA opr Load Accumulator A —(M) easel hua ops EXT |C6/hhil| 4 
LDA opr,X with Memory Byte IX2 |D6\eeff) 5 
LDA opr,X IX1 E6| ff 4 
LDA ,X IX F6 3 
LDX #opr IMM JAE] ii | 2 
LDX opr DIR |BE| dd | 3 
LDX opr Load Index Register X — (M) —|e}s)2fe EXT |CE/hhil| 4 
LDX opr,X with Memory Byte IX2 |DE|eeff} 5 
LDX opr,X IX1 EE| ff 4 
LDX ,X IX FE 3 
LSL opr DIR |38] dd | 5 
LSLA F F ——__—_——_— INH |48 3 
LSLX eons ace os 0 |—j—}r}2]2] INH [58 3 
LSL opr,X b7 bo IX1 |68] ff | 6 
LSL ,X IX 78 5 
LSR opr DIR |34] dd 5 
LSRA —— INH | 44 3 
LSRX Logical Shift Right oO Peic —|—|O}+t])+] INH |54 3 
LSR opr,X b7 b0 IX1 |64] ff | 6 
LSR ,X IX 74 5 
MUL Unsigned Multiply X:A € (X) x (A) 0/—/—|—|0] INH | 42 11 
NEG opr M < —(M) = $00 — (M) DIR |30] ii | 5 
NEGA Alagata Byte A —-(A) = $00 — (A) INH | 40 3 
NEGX ‘Two's Complesnant) X — -(X) = $00 - (X) —|—/+}+]+] INH |50 3 
NEG opr,X M < -(M) = $00 — (M) IX1 60| ff 6 
NEG ,X M < -(M) = $00 — (M) IX |70 5 
NOP No Operation —|—|—|/—|—| INH |9D 2 
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Table 12-6. Instruction Set Summary (Continued) 


Effect on 2 o| 3S | » 
Source — CCR 23 \S\a/2 
Operation Description ~olo/*s|o 
Form Ss i|o|2|> 
H| I |N|Z/C <x O10 1S) 
ORA #opr IMM {AA ii 2 
ORA opr : DIR |BA| dd 3 
panna Arua with A — (A) v (M) eS alas ee i lee oe 
ORA opr,X ger 7 IX2 |DAleeff| 5 
ORA opr,X y IX1 |EA) ff | 4 
ORA ,X IX FA 3 
ROL opr DIR |39] dd 5 
ROLA INH | 49 3 
ROLX Sat eae? a JH}: ]]2] INH J59 3 
ROL opr,X g y b7 b0 IxX1 |69] ff | 6 
ROL ,X IX 79 5 
ROR opr DIR |36) dd | 5 
RORA , INH | 46 3 
RORX fear We = = —|—|t}t}2] INH |56 3 
ROR opr,X 9 y b7 bo IX1 |66| ff | 6 
ROR ,X IX 76 5 
RSP Reset Stack Pointer SP < $00FF —|—|—|/—|—| INH |9C 2 
SP < (SP) + 1; Pull (CCR) 
SP < (SP) + 1; Pull (A) 
RTI Return from Interrupt SP < (SP) + 1; Pull (X) tT) tytytyt INH | 80 9 
SP < (SP) + 1; Pull (PCH) 
SP < (SP) + 1; Pull (PCL) 
Return from SP < (SP) + 1; Pull (PCH) fff 
Bis Subroutine SP < (SP) + 1; Pull (PCL) pie ies 
SBC #opr IMM |A2| ii | 2 
SBC opr DIR |B2| dd | 3 
Subtract Memory 
SBC opr ‘ EXT |C2}/hhil) 4 
SBC opr,X he oe ae) a a —I7]*) 51") 1x2 |p2}eett] 5 
SBC opr,X IX1 E2) ff 4 
SBC ,X IX F2 3 
SEC Set Carry Bit Ce —|—|—|—} 1 INH |99 2 
SEI Set Interrupt Mask 11 —|1/—/—|—| INH |9B 2 
STA opr DIR |B7| dd | 4 
Soe: Store Accumulator in eT eel 32 
STA opr,X RAS iaor M < (A) —|—|t/t|—| IX2 |D7)eeff) 6 
STA opr,X y IX1 |E7] # | 5 
STA ,X IX F7 4 
Stop Oscillator and 
STOP Enable IRQ Pin —!0|—/—|—| INH |8E 2 
STX opr DIR |BF| dd 4 
STX opr Sareindax EXT |CF/hhil) 5 
STX opr,X Piaaisnar ia Wlenior M < (X) —|—|t]t|—| IxX2 |DF/eeff) 6 
STX opr,X g y iX1 |EF] # | 5 
STX ,X IX FF 4 
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Table 12-6. Instruction Set Summary (Continued) 


GENERAL RELEASE SPECIFICATION 


Effecton | % ®'/2 | » 
® |o| & 
: sei ® 2 
Seurce Operation Description CCR SSig, fis 
Form Ss |o|2| > 
H/T |N|Z/C <q O10 oO 
SUB #opr IMM |AO} ii 2 
SUB opr DIR |BO} dd 3 
SUB opr ser eg eee _[|_}.}.f.] ExT Joo} nmi) 4 
SUB opr,X eee IX2 |DOleeff] 5 
SUB opr,X IX1 EO| ff 4 
SUB ,X IX FO 3 
PC < (PC) + 1; Push (PCL) 
SP < (SP) — 1; Push (PCH) 
SP < (SP) — 1; Push (X) 
SP < (SP) — 1; Push (A) Moe ee 
SWI Software Interrupt SP « (SP) — 1; Push (CCR) 1 INH | 83 10 
SP < (SP) -1;1< 1 
PCH < Interrupt Vector High Byte 
PCL < Interrupt Vector Low Byte 
Transfer 
TAX Accumulator to X < (A) —|—|/—|—|—| INH |97 2 
Index Register 
TST opr DIR |3D} dd 4 
TSTA INH |4D 3 
TSTX eee (M) — $00 —|—}:]:;—-) INH [5p 3 
TST opr,X g IX1 |eD] ff | 5 
TST ,X IX 7D 4 
Transfer Index 
TXA Register to A < (X) —|—|—)—|—| INH |9F 2 
Accumulator 
Stop CPU Clock and 
WAIT Enable —|0/—)—|—| INH |8F 2 
Interrupts 
A Accumulator opr Operand (one or two bytes) 
Cc Carry/borrow flag PC Program counter 
CCR _ Condition code register PCH — Program counter high byte 
dd Direct address of operand PCL Program counter low byte 
ddrr Direct address of operand and relative offset of branch instruction REL Relative addressing mode 
DIR Direct addressing mode rel Relative program counter offset byte 
ee ff High and low bytes of offset in indexed, 16-bit offset addressing tr Relative program counter offset byte 
EXT — Extended addressing mode SP Stack pointer 
ff Offset byte in indexed, 8-bit offset addressing x Index register 
H Half-carry flag Z Zero flag 
hh Il High and low bytes of operand address in extended addressing # Immediate value 
| Interrupt mask A Logical AND 
ii Immediate operand byte Vv Logical OR 
IMM Immediate addressing mode ® Logical EXCLUSIVE OR 
INH Inherent addressing mode () Contents of 
IX Indexed, no offset addressing mode -() Negation (two’s complement) 
IxX1 Indexed, 8-bit offset addressing mode e Loaded with 
IX2 Indexed, 16-bit offset addressing mode ” If 
M Memory location : Concatenated with 
N Negative flag t Set or cleared 
n Any bit = Not affected 
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| ASY 
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EErSOOH890W 


Table 12-7. Opcode Map 


Bit Manipulation| Branch Read-Modify-Write Conirol Register/Memory 
DIR DIR REL DIR INH INH IX1 IX INH INH IMM DIR EXT IX2 IX1 IX 
MSB MSB 
fee 0 1 2 3 4 5 6 7 8 9 A B G D E F (sq 
5 5 3 3 6 5 9 3 5 4 3 
0 BRSETO BSETO BRA NEG NEGA NEGX NEG NEG RTI SUB SUB SUB SUB SUB SUB 0 
3 DIR |2 DIR REL |2 DIR|1 INH | 4 INH |2 Ix1|4 Ix|1 INH 2 IMM | 2 DIR |3 EXT|3 1X2} 2 x1 Ix 
5 5 3 6 5 4 3 
1 RRCLRO | BCLRO BRN RTS CMP CMP CMP CMP CMP CMP 1 
2 DIR|2 DIR |2 REL 1 INH 2 IMM | 2 DIR |3 EXT|3 1X2] 2 x1 Ix 
5 5 3 1 3 5 4 3 
2 DRSET1 BSET1 BHI MUL SBC SBC SBC SBC SBC SBC 2 
S DIR |2 DIR |2 REL 1 INH 2 IMM | 2 DIR |3 EXT|3 1X2} 2 x1 Ix 
5 5 3 5 3 6 5 10 3 5 4 3 
3 BRCLR1 BCLR1 BLS COM COMA COMX COM COM SWI CPX CPX CPX CPX CPX CPX 3 
3 DIR |2 DIR |2 REL |2 DIR|1 INH | 4 INH | 2 IX1|4 Ix|1 INH 2 IMM | 2 DIR |3 EXT|3 1X2] 2 x1 Ix 
5 5 3 3 6 5 2 3 4 5 4 3 
4 RRSET2 BSET2 BCC LSR LSRA LSRX LSR LSR AND AND AND AND AND AND 4 
3. DIR |2 DIR REL |2 DIR|1 INH | 4 INH | 2 IX1|4 Ix 2 IMM | 2 DIR |3 EXT|3 1X2} 2 x1 Ix 
5 5 3 2 3 4 5 4 3 
5 ®RCLR2 | BCLR2 | BCS/BLO BIT BIT BIT BIT BIT BIT 5 
& DIR |2 DIR |2 REL 2 IMM | 2 DIR |3 EXT|3 1X2] 2 x1 Ix 
i 5 5 3 3 6 5 3 4 5 4 3 
6 6RSET3 BSET3 BNE ROR RORA RORX ROR ROR LDA LDA LDA LDA LDA LDA 6 
5 DIR |2 DIR |2 REL |2 DIR} 1 NH |1 INH | 2 x1] 1 Ix 2 IMM | 2 DIR |3 EXT|3 1X2] 2 x1 Ix 
5 5 3 5 3 6 5 2 4 5 6 5 4 
7 ERCLR3 | BCLR3 BEQ ASR ASRA ASRX ASR ASR TAX STA STA STA STA STA 7 
3 DIR|2 DIR |2 REL |2 DIR} 1 NH |1 INH |2 x1] 1 Ix 1 INH 2 DIR |3 EXT|3 1X2] 2 x1 Ix 
5 5 3 5 3 3 6 5 2 4 5 4 3 
8 DRSET4 BSET4 BHCC ASL/LSL |ASLA/LSLA|ASLX/LSLX] ASL/LSL | ASL/LSL CLC EOR EOR EOR EOR EOR EOR 8 
5 DIR|2 DIR |2 REL |2 DIR} 1 NH | 1 INH | 2 x1] 1 Ix 1 INH | 2 IMM | 2 DIR |3 EXT|3 1X2} 2 x1 Ix 
5 5 3 5 3 6 5 2 3 4 5 4 3 
9 RRCLR4 | BCLR4 BHCS ROL ROLA ROLX ROL ROL SEC ADC ADC ADC ADC ADC ADC 9 
DIR|2 DIR |2 REL |2 DIR} 1 NH | 1 INH | 2 x1] 1 Ix 1 INH | 2 IMM | 2 DIR |3 EXT|3 1X2] 2 x1 Ix 
5 5 3 5 3 6 5 2 4 5 4 3 
A LRSET5 BSET5 BPL DEC DECA DECX DEC DEC CLI ORA ORA ORA ORA ORA ORA A 
3 DIR |2 DIR REL | 2 DIR} 1 NH | 1 INH |2 x1] 1 Ix 1 INH | 2 IMM | 2 DIR |3 EXT|3 1X2} 2 x1 Ix 
5 5 3 2 3 4 5 4 3 
B RRCLR5 | BCLR5 BMI SEl ADD ADD ADD ADD ADD ADD B 
De DIR |2 DIR |2 REL 1 INH | 2 IMM | 2 DIR |3 EXT|3 1X2} 2 x1 Ix 
5 5 3 3 6 5 2 2 3 4 3 2 
Cc BRSET6 BSET6 BMC INC INCA INCX INC INC. RSP JMP. JMP. JMP. JMP JMP. Cc 
= DIR |2 DIR |2 REL |2 DIR|1 INH | 4 INH | 2 IX1|4 Ix 1 INH 2 DIR |3 EXT|3 IX2 | 2 x1 Ix 
5 5 3 3 5 4 2 5 6 7 6 5 
D RRCLR6 | BCLR6 BMS TST TSTA TSTX TST TST NOP BSR JSR JSR JSR JSR JSR D 
DIR |2 DIR |2 REL |2 DIR|1 INH | 4 INH |2 IX1|4 Ix 1 INH | 2 REL |2 DIR |3 EXT|3 1X2] 2 x1 Ix 
5 5 3 2 3 4 5 4 3 
E 6RSET7 BSET7 BIL STOP LDX LDX LDX LDX LDX LDX E 
. DIR |2 DIR |2 REL 1 INH 2 IMM | 2 DIR |3 EXT|3 1X2] 2 x1 Ix 
5 5 3 3 3 6 2 2 4 5 6 5 4 
F BRCLR7 | BCLR7 BIH CLR CLRA CLRX CLR CLR WAIT TXA STX STX STX STX STX F 
3 DIR |2 DIR |2 REL | 2 DIR|1 INH | 4 INH |2 IX1|4 Ix|1 INH | 4 INH 2 DIR |3 EXT|3 1X2} 2 x1 Ix 
INH = Inherent REL = Relative MSB 
é 0 MSB of Opcode in Hexadecimal 
IMM = Immediate IX = Indexed, No Offset LSB 
= Di = -Bi 5 [Number of Cycles 
DIR = Direct IX1 = Indexed, 8 Bit Offset LSB of Opcode in Hexadecimal 0 BRSETO |Opcode Mnemonic 
EXT = Extended IX2 = Indexed, 16-Bit Offset 3 DIR |Number of Bytes/Addressing Mode 
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SECTION 13 
ELECTRICAL SPECIFICATIONS 


This section provides the electrical and timing specifications for the 
MC68HCO5UB3. 


13.1 MAXIMUM RATINGS 


(Voltages referenced to Vgs) 


Rating Symbol Value Unit 
Supply Voltage Vop —0.3 to +7.0 V 
Bootloader Mode (IRQ/Vpp Pin Only) VIN Vsg — 0.3 to 17 Vv 
Current Drain Per Pin Excluding Vpp and Vsg | 25 mA 
Operating Junction Temperature Ty +150 °C 
Operating Temperature Range T, to Ty 
MC68HCO05JB3 (Standard) Ta 0 to +70 °C 
MC68HC05JB3 (Extended) Ta —40 to +85 °C 
Storage Temperature Range Tstg —65 to +150 °C 
NOTE 


Maximum ratings are the extreme limits the device can be exposed to without 
Causing permanent damage to the chip. The device is not intended to operate at 
these conditions. 


The MCU contains circuitry that protect the inputs against damage from high 
static voltages; however, do not apply voltages higher than those shown in the 
table below. Keep Viy and Voyr within the range from Vgg < (Vin or Voyt) < Vpp- 
Connect unused inputs to the appropriate voltage level, either Vss or Vpp. 


13.2 THERMAL CHARACTERISTICS 


Characteristic Symbol Value Unit 
Thermal Resistance 
20-pin PDIP SAT °C/W 
20-pin SOIC BJA °C/W 
28-pin PDIP 8ya °C/W 
28-pin SOIC 8a °C/W 
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13.3. DC ELECTRICAL CHARACTERISTICS 
Table 13-1. DC Electrical Characteristics 


(Vpp = 4.2V to 5.5V, Vgg = 0 Vde, Ta = 0°C to +70°C, unless otherwise noted) 


Characteristic Symbol Min Typ Max Unit 
Output Voltage VoL — — 0.1 V 
lLoad = 10.0 yA Vou Vopp — 0.1 a — 
Output High Voltage 
(lLoad =—0-8 mA) PAO-7, PBO-2, PB4-7, PC0-3 Vou Vpp — 0.8 — — V 
Output Low Voltage 
(I = 1.6mA) PAO-3, PBO, PB4-7, PC0-3 — — 0.4 
i = 8mA) PA4-7 Vo. = = 0.4 " 
(ll oad = 22MA) PB1, PB2 (see note 8) _ — 0.5 
Input High Voltage 
PAO-7, PBO-2, PB4-7, PC0-3, IRQ, RESET, OSC1 Vin 0.7xVpp — Vpp V 
Input Low Voltage 
PAO-7, PBO-2, PB4-7, PC0-3, IRQ, RESET, OSC1 ViL Vss — 0.2xVpp V 
Supply Current (see Notes) 
Run (USB active) 8 10 mA 
Run (USB suspended) 7.5 ss) mA 
Wait (USB active) Ipp 3 5 mA 
Wait (USB suspended) 2.5 4 mA 
Stop (USB suspended) 
3.3V regulator on 40 100 HA 
I/O Ports Hi-Z Leakage Current 
PAO-7, PB0O-2, PB4-7, PC0-3 | _ _ +10 A 
(without individual pull-down/up activated) z 7 H 
Input Pull-down Current 
PAO-7, PBO, PB4-7, PC0-3 
(with individual pull-down activated) ML 20 we ane BA 
Input Current 
RESET, IRQ, OSC1 lin — — 5 LA 
Capacitance 
Ports (as Input or Output) Cout — — 12 pF 
RESET, IRQ, OSC1, OSC2 Cin — — 8 pF 
Crystal/Ceramic Resonator Oscillator Mode 
Internal Resistor 
OSC1 to OSC2 Rosc 1 2 3 MQ 
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Table 13-1. DC Electrical Characteristics 


(Vpp = 4.2V to 5.5V, Vgg = 0 Vdc, Ta = 0°C to +70°C, unless otherwise noted) 


Characteristic Symbol Min Typ Max Unit 
Pullup Resistor 
PB1, PB2 ReytLup 30 50 75 KQ 
LVR Inhibit (see note 9) Vive\l 3.3 
LVR Recover (see note 9) VivRR 3.5 
TCAP Input Threshold Voltage VtcaP Vpp/2 


NOTES: 

1. All values shown reflect average measurements. 

2. Typical values at midpoint of voltage range, 25°C only. 
3. Wait Ipp: Only MFT and Timer1 active. 
4 


Run (Operating) Ipp, Wait Ipp: Measured using external square wave clock source to OSC1 (fogc = 6.0 
MHz), all inputs 0.2 VDC from rail; no DC loads, less than 50pF on all outputs, C_ = 20 pF on Oc2. 


Wait, Stop Ipp: All ports configured as inputs, Vj, = 0.2 VDC, Viy = Vpp—0.2 VDC. 
Stop Ipp measured with OSC1 = Vgg. 

Wait Ipp is affected linearly by the OSC2 capacitance. 

Ta = 0°C to +40°C. 

These are preliminary specifications. 


13.4 USB DC ELECTRICAL CHARACTERISTICS 
Table 13-2. USB DC Electrical Characteristics 


oaANon 


(Vpp = 4.2V to 5.5V, Vgg = 0 Vdc, Ta = 0°C to +70°C, unless otherwise noted) 


Characteristic Conditions Min Typ Max Unit 
Hi-Z State Data Line Leakage OV<Vin<3.3V -10 +10 HA 
Differential Input Sensitivity |(D+)—(D—)| 0.2 V 
Differential Common Mode Includes Vp; 08 25 V 
Range range 
Single Ended Receiver 
Threshold Of 20 . 
R,_ of 1.5k to 
Static Output Low 3.6V 0.3 V 
R,_ of 15k to 
Static Output High GND 2.8 3.6 V 
3.3V External Reference Pin I_=200uA 3.0 3.3 3.6 V 
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13.5 USB LOW SPEED SOURCE ELECTRICAL CHARACTERISTICS 
Table 13-3. USB Low Speed Source Electrical Characteristics 


Conditions ; : 
Parameter Symbol (Notes 1,2,3) Min Typ Max Unit 
Transition time: Notes 4, 5, 8 
Rise Time TR C,=50pF 75 ns 
C, =350pF 300 ns 
Fall Time Te C,=50pF 75 ns 
C, =350pF 300 ns 
Rise/Fall Time Matching TRemM Tp/Te 80 120 % 
Output Signal Crossover 
Voltage Vors 1.3 2.0 V 
1.4775 1.500 1.5225 Mbs 
+1.5% 
Low Speed Data Rate Tprate | 1.5Mbs +1.5% 676.8 666.0 656.8 a 
Source Differential Driver Jitter 
To Next Transition Tuput Roma 7 -25 25 ns 
For Paired Transitions Tupye —10 10 ns 
Receiver Data Jitter Tolerance 
To Next Transition Tpurt reid -75 75 ns 
For Paired Transitions Tpyr2 —45 45 ns 
Source EOP Width TEOPT Note 7 1.25 1.50 us 
Differential to EOP Transition TDEOP Note 7 _40 100 aS 
Skew 
Receiver EOP Width 
Must Reject as EOP TEOPR1 Note 7 330 ns 
Must Accept TEOPR2 675 ns 
NOTES: 
1. All voltages measured from local ground, unless otherwise specified. 
2. All timings use a capacitive load of 50pF, unless otherwise specified. 
3. Low speed timings have a 1.5k pull-up to 2.8V on the D- data line. 
4. Measured from 10% to 90% of the data signal. 
5. The rising and falling edges should be smooth transitions (monotonic). 
6. Timing differences between the differential data signals. 
7. Measured at crossover point of differential data signals. 
8. Capacitive loading includes 50pF of tester capacitance. 
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13.6 CONTROL TIMING 


Table 13-4. Control Timing 


(Vpp = 4.2V to 5.5V, Vgg = 0 Vde, Ta = 0°C to +70°C, unless otherwise noted) 


Characteristic Symbol Min Max Units 

Frequency of Operation 

Crystal Oscillator Option fosc = 6 MHz 

External Clock Source fosc DC 6 MHz 
Internal Operating Frequency 

Crystal Oscillator (fog¢ + 2) fop = 3 MHz 

External Clock (fogc + 2) fop DC 3 MHz 
Cycle Time (1/fop) teyc 330 — ns 
RESET Pulse Width Low taL 1.5 — tcyc 
IRQ Interrupt Pulse Width Low (Edge-Triggered) tH 0.5 — tcyc 
IRQ Interrupt Pulse Period tL note 1 — tcyc 


PAO to PAS Interrupt Pulse Width High 


(Edge-Triggered) TIL oe — 'cyc 
PAO to PAS Interrupt Pulse Period tHIH note 1 — tcyc 
OSC1 Pulse Width ton: tot _ _ ns 
Output High to Low Transition Period on t de 
PA6, PA7, PBO-4 phevt 

NOTES: 

1. The minimum period ty, j_ or ty4)4 Should not be less than the number of cycles it takes to execute the 
interrupt service routine plus 19 teyc. 

2. Effects of processing, temperature, and supply voltage (excluding tolerances of external R and C) 

3. — tgiow iS a parameter dependent on fogc¢ and loading. Typical value of tgioy is TENTATIVELY set at 170 ns 
with minimal value of 130ns and maximal value of 185ns under the SIMULATION conditions that fosc 
is 6.0 MHz and slow output transition feature is enabled. Actual transition time will be specified to 
replace the TBDs when enough characterization has been done on various wafers from different lots. 
The values listed here represent data off simulation runs under the specified conditions. Under no cir- 
cumstances should they be treated as the final specification. 
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SECTION 14 
MECHANICAL SPECIFICATIONS 


This section provides the mechanical dimensions for the 20-pin SDIP, and 
28-pin SDIP, 20-pin SOIC, and 28-pin SOIC packages. 


14.1. 20-PIN PDIP (CASE 738) 


—A- 
NOTES: 
a Ay ty pt 1. DIMENSIONING AND TOLERANCING PER ANS! 
Y14.5M, 1982. 
2. CONTROLLING DIMENSION: INCH. 
3. DIMENSION L TO CENTER OF LEAD WHEN 
FORMED PARALLEL. 
4. DIMENSION B DOES NOT INCLUDE MOLD 
FLASH. 
Cc —— L 
INCHES | MILLIMETERS 
pim{_MIN- | MAX |_MIN | MAX 
A | 1.010 | 1.070 | 25.66 | 27.17 
—_Y B | 0240 | 0260 | 610 | 6.60 
_T- rx / \ c [0.150 | 0.180 | 381 | 4.57 
rete | {/ \ pd | 0.015 | 0.022 | 039 | 0.55 
PLANE M E | 0.050BSC 1.27 BSC 
N WZ F | 0.050 | 0.070 | 4.27 [1.77 
E =) G | 0.100BSC 2.54 BSC 
G F J [0008 [0.015 | 021 | 0.38 
—>\<— J 20PL K_| 0.110 | 0.140 2.80 3.55 
L | 0.300 BSC 7.62 BSC 
D 20 PL > 0.25 (0.010)@|T| B @ M 0°] 15° 0°] 15° 
| 0.25 (0.010) @ TIA ® Nn [0.020 [ 0.040 | 051 | 1.01 


Figure 14-1. 20-Pin PDIP Mechanical Dimensions 
14.2 28-PIN PDIP (CASE 710) 


NOTES: 

1. POSITIONAL TOLERANCE OF LEADS (D), 
SHALL BE WITHIN 0.25mm (0.010) AT 
MAXIMUM MATERIAL CONDITION, IN 
RELATION TO SEATING PLANE AND 


EACH OTHER. 
2. DIMENSION LTO CENTER OF LEADS 
WHEN FORMED PARALLEL. 
3. DIMENSION B DOES NOT INCLUDE 
MOLD FLASH. 
MILLIMETERS INCHES 
DIM_|_ MIN MAX MIN | MAX 
A 36.45 | 37.21 | 1.4385 | 1.465 
L B 13.72 | 14.22 | 0.540 | 0.560 
Cc 3.94 | 5.08 | 0.155 | 0.200 
D 0.36 | 0.56 | 0.014 | 0.022 
F 1.02 | 1.52 | 0.040 | 0.060 
G 2.54 BSC 0.100 BSC 
H 1.65 | 2.16 | 0.065 | 0.085 
Joi J 0.20 | 0.38 | 0.008 | 0.015 
M K 2.92 | 3.43 | 0.115 | 0.135 
SEATING L 15.24 BSC 0.600 BSC 
M 0° 15° 0° 15° 
Fone N 0.51 1.02 | 0.020 | 0.040 


Figure 14-2. 28-Pin PDIP Mechanical Dimensions 
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14.3 20-PIN SOIC (CASE 751D) 


SI Y14.5M, 1982. 
ONTROLLING DIMENSION: MILLIMETER. 
IMENSIONS A AND B DO NOT INCLUDE 
OLD PROTRUSION. 
|AXIMUM MOLD PROTRUSION 0.150 
.006) PER SIDE. 
. DIMENSION D DOES NOT INCLUDE 
AMBAR PROTRUSION. ALLOWABLE 

AMBAR PROTRUSION SHALL BE 0.13 
.005) TOTAL IN EXCESS OF D DIMENSION 
MAXIMUM MATERIAL CONDITION. 


—A— NOTES: 
P a" 1. DIMENSIONING AND TOLERANCING PER 
20 1 


Qrgw 


2: 
A 3. 


4. 


$ 
a2) 


—B-| 10x P 
(o) | 0.010 (0.25)@) 


= 20x D 


MILLIMETERS | INCHES 
J MIN | MAX | MIN | MAX 
)}0.010 (0.25)@|T| A © | B® . 12.65 | 12.95 | 0.499 | 0.510 
a 7.40 | 7.60 | 0.292 | 0.299 
adele 


2.35 [| 2.65 | 0.093 | 0.104 
a R x 45° 
— 


0.35 0.49 | 0.014 | 0.019 
—T_] SEATING = 
PLANE a 
M 


0.50 0.90 | 0.020 | 0.035 
Figure 14-3. 20-Pin SOIC Mechanical Dimensions 


Ss 


ioe] 
i) 
a 
000 


S 
as 


g 
= 


BSC 0.050 BSC 
0.25 0.32 _| 0.010 | 0.012 
0.10 0.25 | 0.004 | 0.009 

0° be 0° 72 

10.05 | 10.55 | 0.395 | 0.415 

0.25 0.75 | 0.010 | 0.029 


B)Vj=E/Rle|O|njolo|a]> 
ip 
N 


14.4 28-PIN SOIC (CASE 751F) 


NOTES: 
Pp 1. DIMENSIONING AND TOLERANCING PER 
14X ANSI Y14.5M, 1982. 
2. CONTROLLING DIMENSION: MILLIMETER. 
I 0.010 (0.25) ® | B® 3. DIMENSION A AND B DO NOT INCLUDE MOLD 
PROTRUSION. 
4, MAXIMUM MOLD PROTRUSION 0.15 
(0.006) PER SIDE. 
\_ 5. DIMENSION D DOES NOT INCLUDE 
rc DAMBAR PROTRUSION. ALLOWABLE 
28x D 7 - DAMBAR PROTRUSION SHALL BE 0.13 
(0.005) TOTAL IN EXCESS OF D 
| 0.010 (0.25) @ |T| A© | B© DIMENSION AT MAXIMUM MATERIAL 
R x 45° CONDITION. 
ye | MILLIMETERS INCHES 
T- pim | MIN | MAX | MIN | MAX 
oi K \ A_| 17.80 | 18.05 | 0.701 | 0.711 
Seanad \ B | 740 | 7.60 | 0.292 | 0.299 
=< Cc 2.35 | 2.65 | 0.093 | 0.104 
PLANE iy D_| 035 | 049 | 0.014 | 0.019 
E F | 041 | 0.90 | 0.016 | 0.035 
| G 1.27 BSC 0.050 BSC 
a J | 023 [ 032 [ 0.009 | 0.013 
J K | 0.13 | 0.29 | 0.005 | 0.011 
M oe ee | 0° 8° 
P| 10.05 | 10.55 | 0.395 | 0.415 
R_| 025 | 075 | 0.010 | 0.029 
Figure 14-4. 28-Pin SOIC Mechanical Dimensions 
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APPENDIX A 
MC68HC705JB3 
This appendix describes the MC68HC705JB3, the emulation part for 


MC68HCO5JB3. The entire MC68HCO5JB3 data sheet applies to the 
MC68HC705JB3, with exceptions outlined in this appendix. 


A.1. INTRODUCTION 
The MC68HC705JB3 is an EPROM version of the MC68HCO5JB3, and is avail- 
able for user system evaluation and debugging. The MC68HC705JB3 is function- 
ally identical to the MC68HCO5JB3 with the exception of the 2560 bytes user 
ROM is replaced by 2560 bytes user EPROM. Also, the mask options available on 
the MC68HC05JB3 are implemented using the Mask Option Register (MOR) in 
the MC68HC705JB3. 
The MC68HC705JB3 is not available in the 20-pin SOIC package. 

A.2. MEMORY 
The MC68HC705JB3 memory map is shown in Figure A-1. 

A.3. MASK OPTION REGISTER (MOR) 
The Mask Option Register (MOR) is a byte of EPROM used to select the features 
controlled by mask options on the MC68HCO5JB3. In order to program this regis- 
ter the MORON bit in PCR need to be set to “1” before doing the EPROM pro- 
gramming process. 

BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
pias a COPEN | IRQTRIG |PULLREN| PAINTEN | OSCDLY | LVREN 
$01FF |W 

reset: 0 0 1 1 1 1 1 1 
COPEN -— COP Enable 
1 = COP watchdog function disabled. 
0= COP watchdog function enabled. 
IRQTRIG — IRQ, PAO-PA3 Interrupt Option 
1= lEdge-triggered only. 
0= Edge-and-level-triggered. 
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PULLREN - Port A, B, and C Pull-up/down Option 
1= Connected. 
0= Disconnected 


PAINTEN — PAO-PA3 External Interrupt Option 
1= External interrupt capability on PAO-PA3 disabled. 
0= External interrupt capability on PAO-PA3 enabled. 


OSCDLY - Oscillator Delay Option 
1 = 224 internal clock cycles. 
0= 4064 internal clock cycles. 


LVREN — LVR Option 
1= Low Voltage Reset circuit enabled. 
0= Low Voltage Reset circuit disabled. 


$0000 $0000 
\/O Registers 
64 Bytes 
$003F I/O Registers 
0040 eae 
: Unused Pa 64 Bytes 
48 Bytes Sere Ft TH at aee, ae ctype th cal ba ONS 92 ate Se 
$006F a oie EPROM Program Control Register | $003E 
$0070 mies Pieris een a eres beers $003F 
User RAM 
| —ss:144 Bytes os Reserved $1FFO 
sone) | 64 Byte Stack ; R d $1FFI 
' eserve 
S00FF yte Stac F 
Unused: 256 Bytes ‘a Reserved $1FF2 


$01FF| Mask Option Register : peeelad SIFES 


MFT Vector (High Byte) $1FF4 


Wnuead MFT Vector (Low Byte) $1FF5 

4608 Bytes wv Timer1 Vector (High Byte) $1FF6 

$13FF : Timer1 Vector (Low Byte) $1FF7 

$1400 a USB Vector (High Byte) $1FF8 

User EPROM ” USB Vector (Low Byte) | $1FF9 

2560 Bytes = IRQ Vector (High Byte) | $1FFA 

$1DFF ie IRQ Vector (Low Byte) $1FFB 

S1EU0 Bootloader ROM SWI Vector (High Byte) $1FFC 

Site 496 Bytes a SWI Vector (Low Byte) | $1FFD 

$1FFO User Vectors Reset Vector (High Byte) | $1FFE 

$1 FFF 16 Bytes Reset Vector (Low Byte) $1 FFF 

Figure A-1. MC68HC705JB3 Memory Map 
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BOOTSTRAP MODE 


Bootloader mode is entered upon the rising edge of RESET if the IRQ/Vpp pin is 
at Vrst and the PBO pin is at logic zero. The Bootloader program is masked in the 
ROM area from $1E00 to $1FEF. This program handles copying of user code from 
an external EPROM into the on-chip EPROM. The bootload function has to be 
done from an external EPROM. The bootloader performs one programming pass 
at 1ms per byte then does a verify pass. 


The user code must be a one-to-one correspondence with the internal EPROM 
addresses. 
EPROM PROGRAMMING 


Programming the on-chip EPROM is achieved by using the Program Control Reg- 
ister located at address $3E. 


Please contact Motorola for programming board availability. 


EPROM Program Control Register (PCR) 


This register is provided for programming the on-chip EPROM in the 
MC68HC705JB3. 


BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0 
PCR R 0 0 0 0 0 
$003E Ww R R R R R 
reset: 0 0 0 0 0 0 0 0 

R = Reserved 


MORON ELAT PGM 


MORON - Mask Option Register ON 
0= Disable programming to Mask Option Register ($01 FF) 
1 = Enable programming to Mask Option Register ($01 FF) 


ELAT — EPROM LATch control 

0 EPROM address and data bus configured for normal reads 

1 EPROM address and data bus configured for programming (writes 
to EPROM cause address and data to be latched). EPROM is in 
programming mode and cannot be read if ELAT is 1. This bit should 
not be set when no programming voltage is applied to the V_,, pin. 


PGM — EPROM ProGraM command 
0= Programming power is switched OFF from EPROM array. 
1= Programming power is switched ON to EPROM array. If ELAT#1, 
then PGM=0. 


Bits [7:3] — Reserved 
These are reserved bits and should remain zero. 
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A.5.2 Programming Sequence 


The EPROM programming sequence is: 


1. 


a a es 


6. 


The last two steps must be performed with separate CPU writes. 


Set the ELAT bit 

Write the data to the address to be programmed 
Set the PGM bit 

Delay for a time tpgmr 

Clear the PGM bit 

Clear the ELAT bit 


CAUTION 


It is important to remember that an external programming voltage must be applied 
to the Vpp pin while programming, but it should be equal to Vpp during normal 
operations. 


Figure A-2 shows the flow required to successfully program the EPROM. 
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Write 
additional 
byte? 


Figure A-2. EPROM Programming Sequence 
A.6 EPROM PROGRAMMING SPECIFICATIONS 
Table A-1. EPROM Programming Electrical Characteristics 


(Vpp = 4.2V to 5.5V, Vsg = 0 Vdc, Ta = 0°C to +70°C, unless otherwise noted) 


Characteristic Symbol Min Typ Max Unit 
Programming Voltage 
IRQ/Vpp Vpp 10 12 15 V 
Programming Current 
IRQ/V pp Ipp — 3 — mA 
Programming Time 
per byte tepam 1 4 — ms 
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